我基本上有一个包含数据的文本文件,其中包含此格式的次数
(00:00)
(06:08)
(07:54)
我已经完成了我的研究,以确定如何只采用那些时间(过滤掉所有其他的gunk),甚至使用awk分离它们。当我尝试添加数字时会发生此问题。我似乎得到一个数字0值......
我的代码如下:
cat somefile.txt | awk -F: '/([0-9][0-9]:[0-9][0-9])/{total+=$1}END{print total}'
注意:我使用括号,因为该文件包含其他时间,不包含在括号中......所以我试图摆脱不需要的数据,只留下上面的部分(00:00)
我正在尝试将左侧部分添加到一起,显然在此示例中总共会产生13个。
真的希望我能找到一个解决方案,而且我确信这一点目前并不是我想到的。
答案 0 :(得分:5)
试试这一行:
awk -F'[(:]' '{h+=$2}END{print h}' file
示例:
kent$ echo "(00:00)
(06:08)
(07:54)"|awk -F'[(:]' '{h+=$2}END{print h}'
13
修改强>
[(:]
(我真的想要输入:)
)定义两个FS(字段分隔符)s (
或:
,所以该行将是:
(06:08)
field 1 - ""
field 2 - 06
field 3 - 08)
如果您只需要几分钟,则需要将)
添加到您的FS,否则您的$3
结尾为)
。