如果使用 sed 找到模式 1 和模式 2,则删除 bash 删除



我需要删除文件中具有两个单独关键字的所有行

示例文件:

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`

相关内容

  • 没有找到相关文章

最新更新