awk打印列$ 3如果$ 2 ==一个特定的值?
我从awk编程语言学习awk,并被这个例子困扰。
如果我想打印$ 3,如果$ 2等于一个值(eg'1'),我正在使用这个工作正常的命令:
awk '$2==1 {print $3}' <infile> | more
但是当我用另一个search条件replace1时,例如'findtext',这个命令不起作用。
awk '$1== findtext {print $3}' <infile> | more
这不返回任何输出,我敢肯定,我在“findtext”中存在的地方。 我的语法有什么问题吗?
我试过,但它不工作:
awk '$1== "findtext" {print $3}' <infile> | more
但是当我这样做
grep findtext <infile> ## This does give me output
findtext存在于$ 1中,因为我仔细检查。
这里是我的testing文件名为“testing”,例如,它有9行和8个字段和空格分隔:
1 11 0.959660297 0 0.021231423 -0.0073 -0.0031 MhZisp 2 14 0.180467091 0.800424628 0 0.0566 0.0103 ClNonZ 3 19 0.98089172 0 0 -0.0158 0.0124 MhNonZ 4 15 0.704883227 0.265392781 0.010615711 -0.0087 -0.0092 MhZisp 5 22 0.010615711 0.959660297 0.010615711 0.0476 0.0061 ClNonZ 6 23 0.715498938 0 0.265392781 -0.0013 -0.0309 Unkn 7 26 0.927813163 0 0.053078556 -0.0051 -0.0636 MhZisp 8 44 0.55626327 0.222929936 0.201698514 0.0053 -0.0438 MhZisp 9 31 0.492569002 0.350318471 0.138004246 0.0485 0.0088 ClNonZ
这是我做的和输出:
$awk '$8 == "ClNonZ" {print $3}' test $ grep ClNonZ test 2 14 0.180467091 0.800424628 0 0.0566 0.0103 ClNonZ 5 22 0.010615711 0.959660297 0.010615711 0.0476 0.0061 ClNonZ 9 31 0.492569002 0.350318471 0.138004246 0.0485 0.0088 ClNonZ
我希望看到这是$ 8的“ClNonZ”$ 3。
0.180467091 0.010615711 0.492569002
不知道为什么awk命令没有返回任何东西。 有什么想法吗?
如果你正在寻找一个特定的string,请在它周围加引号:
awk '$1 == "findtext" {print $3}'
否则,awk会认为它是一个variables名。
这个方法使用正则expression式,它应该工作:
awk '$2 ~ /findtext/ {print $3}' <infile>
根据AWK
实现,你使用==
是否可以。
你有没有试过~
? 例如,如果你想$ 1是“你好”:
awk '$1 ~ /^hello$/{ print $3; }' <infile>
^
表示$ 1开始, $
是$ 1结束。
我的awk版本是3.1.5。
是的,input文件是空格分开的,没有标签。
根据arutaku的回答,这是我尝试过的工作:
awk '$8 ~ "ClNonZ"{ print $3; }' test 0.180467091 0.010615711 0.492569002 $ awk '$8 ~ "ClNonZ" { print $3}' test 0.180467091 0.010615711 0.492569002
什么都行不通(我不知道为什么,也许是由于我的awk版本:),
$awk '$8 ~ "^ClNonZ$"{ print $3; }' test $awk '$8 == "ClNonZ" { print $3 }' test
谢谢大家的回答,意见和帮助!
这对我来说更具可读性
awk '{if ($2 ~ /findtext/) print $3}' <infile>
请试试这个
echo $VAR | grep ClNonZ | awk '{print $3}';
要么
echo cat filename | grep ClNonZ | awk '{print $3}';