簡體   English   中英

使用帶有列值條件的 awk

[英]using awk with column value conditions

我正在從The AWK Programming Language學習 awk 並且我對其中一個示例有問題。

如果我想在 $2 等於一個值(例如1 )時打印 $3 ,我正在使用這個工作正常的命令:

awk '$2==1 {print $3}' <infile> | more

但是當我用另一個搜索條件(例如findtext )替換 1 時,該命令不起作用:

awk '$1== findtext {print $3}' <infile> | more

它不返回任何輸出,我確定輸入文件中存在“findtext”。

我也試過這個,但它不起作用:

awk '$1== "findtext" {print $3}' <infile> | more

這是我的名為“test”的測試文件,它有 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

我希望看到這是 3 美元,在他們的 8 美元中有“ClNonZ”。

0.180467091 
0.010615711 
0.492569002

不知道為什么 awk 命令沒有返回任何內容。 有什么想法嗎?

如果您要查找特定字符串,請在其周圍加上引號:

awk '$1 == "findtext" {print $3}'

否則,awk 將假定它是一個變量名。

此方法使用正則表達式,它應該可以工作:

awk '$2 ~ /findtext/ {print $3}' <infile>

根據AWK實現,您使用==是否可以。

你試過嗎~ ?。 例如,如果您希望 $1 為“hello”:

awk '$1 ~ /^hello$/{ print $3; }' <infile>

^表示 $1 開始, $表示 $1 結束。

這對我來說更具可讀性

awk '{if ($2 ~ /findtext/) print $3}' <infile>

我的 awk 版本是 3.1.5。

是的,輸入文件是空格分隔的,沒有制表符。

根據 rutaku 的回答,這是我嘗試過的有效方法:

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

感謝大家的回答、評論和幫助!

請試試這個

echo $VAR | grep ClNonZ | awk '{print $3}';

或者

echo cat filename | grep ClNonZ | awk '{print $3}';

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM