加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

bash – 从时间中移除秒数(awk,sed)

发布时间:2020-12-16 01:52:37 所属栏目:安全 来源:网络整理
导读:我有这样一个文件: XX1,1.1,24.08.1994 13:00:00,111,112,113XX2,1.2,24.08.1994 13:30:00,121,122,123XX3,NaN,22.08.1995 15:00,131,132,133 所以时间格式不一致.有些行的时间类似于hh:mm:ss,有些行的时间格式为hh:mm.我想删除秒并得到这样的文件: XX1
我有这样一个文件:

XX1,1.1,24.08.1994 13:00:00,111,112,113
XX2,1.2,24.08.1994 13:30:00,121,122,123
XX3,NaN,22.08.1995 15:00,131,132,133

所以时间格式不一致.有些行的时间类似于hh:mm:ss,有些行的时间格式为hh:mm.我想删除秒并得到这样的文件:

XX1,24.08.1994 13:00,24.08.1994 13:30,133

到目前为止我尝试过的是

#!/bin/bash
sed 's@,(..):(..):(..) @,1:2 @' < time_fault > ./time_corrected

#!/usr/bin/awk -f
BEGIN { RS="," ; FS=":"; ORS=","}
{ getline str
gsub(/*..:..:..*/,$1":"$2 str) > time_corrected }

但两者都不起作用.

解决方法

使用sed只需要一个捕获组:

sed -re 's/([0-9]{2}:[0-9]{2}):[0-9]{2},/1,/' -e 's/,+/,/g' file
XX1,133

也许awk更好..如果需要,只在第三个字段上应用替换,否则从第四个字节中移除额外的空格:

$awk '{if ($3~/([0-9]{2}:){2}/) sub(/:[0-9]{2},/,",$3);else sub(/ */,"",$4)}1'
XX1,133

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读