我需要删除文件中具有两个单独关键字的所有行
示例文件:
2 563587992014-01-26 2014-01-26T09:45:53 DC 14003 5 3.60
2 563589242014-01-26 2014-01-26T10:03:13 DC 14003 6 4.80
2 563589252014-01-26 2014-01-26T10:03:20 DC 14002 2 5.50
2 563589272014-01-26 2014-01-26T10:03:34 DC 14002 3 3.30
我想删除所有带有"DC"和"14003"的行。
我正在试验 sed
var1="DC"
var2="14003"
sed -i /$var1/$var2/d /path/file
但它不起作用。 谁能帮忙?
sed '/14003/{/DC/d}'
这确实:
删除所有包含"DC"和"14003"的行。
如果将 SED 与外壳变量一起使用,请使用双引号:
sed "...$FOO...$BAR.."
您可以使用awk
,它非常简单:
$ awk '$5 != 14003 && $4~/DC/' file
2 563589252014-01-26 2014-01-26T10:03:20 DC 14002 2 5.50
2 563589272014-01-26 2014-01-26T10:03:34 DC 14002 3 3.30
要更新文件,您必须将输出重定向到新文件。然后,您可以将前者替换为新的mv
:
awk '$5 != 14003 && $4~/DC/' file > new_file && mv new_file file
使用 awk
awk '!/DC/ || !/14003/' file
2 563589252014-01-26 2014-01-26T10:03:20 DC 14002 2 5.50
2 563589272014-01-26 2014-01-26T10:03:34 DC 14002 3 3.30
使用变量:
var1="DC"
var2="14003"
awk '$0!~v1 || $0!~v2' v1="$var1" v2="$var2" file
2 563589252014-01-26 2014-01-26T10:03:20 DC 14002 2 5.50
2 563589272014-01-26 2014-01-26T10:03:34 DC 14002 3 3.30
你可以使用 perl 来实现这一点:
perl -i -lne 'print unless(/DC/ and /14003/)' your_file
注意:这将进行就地替换。
如果您希望将其包含在 shell 脚本中,那么以下是执行此操作的方法:
#!/bin/ksh
one="DC"
two="14003"
three=`perl -i -lne "print unless(/$one/ and /$two/)" temp`