Windows XP Windows 7 Windows 2003 Windows Vista Windows教程綜合 Linux 系統教程
Windows 10 Windows 8 Windows 2008 Windows NT Windows Server 電腦軟件教程
 Windows教程網 >> Linux系統教程 >> Linux教程 >> awk 多行合並【next 使用介紹】(常見應用4)

awk 多行合並【next 使用介紹】(常見應用4)

日期:2017/2/7 14:26:13      編輯:Linux教程
 

在awk進行文本處理時候,我們可能會遇到。將多行合並到一行顯示問題。 有點象sql裡面,經常遇到的行轉列的問題。 這裡需要用到next語句。

 

awknext語句使用:在循環逐行匹配,如果遇到next,就會跳過當前行,直接忽略下面語句。而進行下一行匹配。

text.txt 內容是:

a
b
c
d
e

 

[chengmo@centos5 shell]$ awk 'NR%2==1{next}{print NR,$0;}' text.txt    
2 b
4 d

當記錄行號除以2余 1,就跳過當前行。下面的print NR,$0也不會執行。 下一行開始,程序有開始判斷NR%2 值。這個時候記錄行號是:2 ,就會執行下面語句塊:'print NR,$0'

 

 

awk next使用實例:

要求:

文件:text.txt 格式:
web01[192.168.2.100]

httpd            ok
tomcat               ok
sendmail               ok
web02[192.168.2.101]
httpd            ok
postfix               ok
web03[192.168.2.102]
mysqld            ok
httpd               ok

 

需要通過awk將輸出格式變成:

web01[192.168.2.100]:   httpd            ok
web01[192.168.2.100]:   tomcat               ok
web01[192.168.2.100]:   sendmail               ok
web02[192.168.2.101]:   httpd            ok
web02[192.168.2.101]:   postfix               ok
web03[192.168.2.102]:   mysqld            ok
web03[192.168.2.102]:   httpd               ok

 

分析:

分析發現需要將包含有“web”行進行跳過,然後需要將內容與下面行合並為一行。

[chengmo@centos5 shell]$ awk '/^web/{T=$0;next;}{print T":\t"$0;}' test.txt

web01[192.168.2.100]:   httpd            ok
web01[192.168.2.100]:   tomcat               ok
web01[192.168.2.100]:   sendmail               ok
web02[192.168.2.101]:   httpd            ok
web02[192.168.2.101]:   postfix               ok
web03[192.168.2.102]:   mysqld            ok
web03[192.168.2.102]:   httpd               ok

 

next在多行合並,以及選擇性輸出方面,非常方便。大家在使用時候不妨試試。

Copyright © Windows教程網 All Rights Reserved