簡體   English   中英

使用AWK打印特定列

[英]Print Specific Columns using AWK

我正在嘗試從制表符分隔的文件“ FILE”中將數據從B列提取到D列。 我使用的簡單AWK代碼獲取數據,但不幸的是,將輸出保留在單個列中並刪除了標識符(如下所示)。

有任何建議請。

 awk '{for(i=2;i<=4;++i)print $i}' FILE

文件

           A            B               C               D               E               F             G
   1_at   10.8435630935 10.8559287854   8.6666141543    8.820310681     9.9024050571    8.613199083   11.9807771094
   2_at   4.7615531106  4.5209119307    11.2467919586   8.8105151099    7.1831990104    11.0645055836 4.3726598561
   3_at   6.0025262754  5.4058080843    3.2475272982    3.1869728585    3.5654989547    

獲得的輸出

B
C
D
10.8435630935
10.8559287854
8.6666141543
4.7615531106
4.5209119307
11.2467919586
6.0025262754
5.4058080843
3.2475272982

為什么不直接使用cut

$ cut -d$'\t' -f2-4 < file
B C D
10.8435630935 10.8559287854 8.6666141543
4.7615531106 4.5209119307 11.2467919586
6.0025262754 5.4058080843 3.2475272982

使用awk您將需要printf以避免出現新的print行:

awk -F"\t" '{for(i=2;i<=4;++i) printf "%s%s", $i, (i==4?RS:FS)}'

暫無
暫無

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

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