1

我有一组输出文件,其中一些如下:

133 0.00295 nurse merit respect muslim 
134 0.00292 high dangerous reassure full 
135 0.00048 
136 0.0039  experience darren  
137 0.00097 _ _param_ui_control_scripts_save _param_pattern_value 
138 0.00292 find director

我想得到以下文件:

133 0.00295 nurse merit respect muslim 
134 0.00292 high dangerous reassure full 
136 0.0039  experience darren  
137 0.00097 _ _param_ui_control_scripts_save _param_pattern_value 
138 0.00292 find director

如果第二列之后没有任何内容,只想删除该特定行。我怎么能做到这一点我对shell脚本很陌生?

可能是这个命令的修改? sed '/^$/d'

4

2 回答 2

6

如果列是空格分隔的,那么检查行是否有两个以上的字段呢?由于NF存储了这个值,你可以简单地说:

awk 'NF>2' file

对于您给定的输入,它返回:

133 0.00295 nurse merit respect muslim 
134 0.00292 high dangerous reassure full 
136 0.0039  experience darren  
137 0.00097 _ _param_ui_control_scripts_save _param_pattern_value 
138 0.00292 find director
于 2015-11-17T11:45:05.927 回答
1

只是为了好玩,我将其sed作为 OP 开始使用,并保持详细的解决方案格式,以防在选择要删除的行时日志文件的确切布局可能会发挥作用。在这里,正则表达式查找行首,后跟 0 个或多个数字,后跟一个空格,后跟零个或多个数字,后跟一个文字句点,后跟零个或多个数字,零个或多个空格,然后是结尾该行并删除它们。

sed '/^[0-9]* [0-9]*\.[0-9]* *$/d' x.log > x_modded.log

有趣的是,在我在 Ubuntu 上的 bash 版本中,我无法使用 \d 的速记来表示一个数字,而用加号表示一个或多个数字。看来是时候进行一些更新了。:-/

于 2015-11-17T16:43:04.850 回答