bash – 根据列中的值选择行
发布时间:2020-12-15 17:02:19 所属栏目:安全 来源:网络整理
导读:我有一个制表符分隔表,我想要打印列’x’大于’Y’的所有行.我尝试使用下面的代码,但我是使用awk的新手,所以我不确定如何根据列使用它. awk '$X = Y {print} ' Table.txt | cat Wanted_lines Y是1到100之间的值. 如果输入如下,列X是第二列. 1 302 503 1004 1
我有一个制表符分隔表,我想要打印列’x’大于’Y’的所有行.我尝试使用下面的代码,但我是使用awk的新手,所以我不确定如何根据列使用它.
awk '$X >= Y {print} ' Table.txt | cat > Wanted_lines Y是1到100之间的值. 如果输入如下,列X是第二列. 1 30 2 50 3 100 4 100 5 80 6 79 7 90 想要的输出是: 3 100 4 100 5 80 7 90 该文件的前两行是: 1 OTU1 243622 208679 121420 265864 0 0 2 0 0 11 1 5 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 839604 OTU1 - Archaea 100% Euryarchaeota 100% Methanobacteria 100% Methanobacteriales 100% Methanobacteriaceae 100% Methanobrevibacter 100% 2 OTU2 84366 120817 15834 74737 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 295755 OTU2 - Archaea 100% Euryarchaeota 100% Methanobacteria 100% Methanobacteriales 100% Methanobacteriaceae 100% Methanobrevibacter 100%
第一
awk的默认内部字段分隔符(FS)将适用于空格或制表符分隔文件. 其次 awk '$x > FLOOR' Table.txt 其中$x是目标列,FLOOR是实际的数字楼层(即5000等)… 示例文件:awktest 500 100 400 1100 1000 400 1200 500 awk '$1 > 1000' awktest 1200 500 awk '$1 >= 1000' awktest 1000 400 1200 500 因此,您应该能够使用关系表达式来打印x> 1的行. y,形式如下: awk '$x > $y' awktest 其中$x是一个数字列,如$1或其他. 其中$y是数字列,如$2或其他. 例: awk '$1 > $2' awktest 要么 … awk '$2 > $1' awktest awk数字是浮点数,所以你也可以比较小数. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |