我有一个数据文件,例如:
数据:
arht -0.1006 0.0001 0.0147 100 arht 0.0012 -0.0002 0.0182 100
arht -0.0006 1.0006 0.0133 100 arht 0.1011 0.0003 0.0175 100
bcmn 0.0005 0.0011 0.0165 100 bcmn 0.0015 0.0007 0.0197 100
ffgf -0.0009 0.0012 0.0121 100 ffgf 0.0007 0.0010 0.0150 100
ffgf -0.0004 0.0009 0.0105 100 ffgf 0.1008 0.0006 0.0151 100
我使用以下命令提取 2-3-4 和 7-8-9 列中绝对值高于 0.10 的行:
awk 'sqrt($2*$2)<=.1 || sqrt($3*$3)>=.1 || sqrt($4*$4)>=.1 || sqrt($7*$7)>=.1 || sqrt($8*$8)>=.1 || sqrt($9*$9)>=.1 {print}' data > output
我需要从数据文件中删除这些行。我该如何修改上述代码?
答案1
似乎是重复的问题提取文本文件里大于阈值的值? 如果是这样,您需要更正代码的第一个项:
awk 'sqrt($2*$2)>=.1 || sqrt($3*$3)>=.1 || sqrt($4*$4)>=.1 || sqrt($7*$7)>=.1 || sqrt($8*$8)>=.1 || sqrt($9*$9)>=.1) {print}' data >output
然后您要做的就是在前面添加一个负号(!)即可得到您想要的结果:
awk '!(sqrt($2*$2)>=.1 || sqrt($3*$3)>=.1 || sqrt($4*$4)>=.1 || sqrt($7*$7)>=.1 || sqrt($8*$8)>=.1 || sqrt($9*$9)>=.1) {print}' data > output