欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

awk 多行合并(next 使用介紹) (常見應(yīng)用4)

  發(fā)布時(shí)間:2013-11-19 22:18:15   作者:佚名   我要評(píng)論
在awk進(jìn)行文本處理時(shí)候,我們可能會(huì)遇到。將多行合并到一行顯示問題。 有點(diǎn)象sql里面,經(jīng)常遇到的行轉(zhuǎn)列的問題。 這里需要用到next語(yǔ)句

awknext語(yǔ)句使用:在循環(huán)逐行匹配,如果遇到next,就會(huì)跳過當(dāng)前行,直接忽略下面語(yǔ)句。而進(jìn)行下一行匹配。


復(fù)制代碼
代碼如下:

text.txt 內(nèi)容是:
a
b
c
d
e

[chengmo@centos5 shell]$ awk 'NR%2==1{next}{print NR,$0;}' text.txt
2 b
4 d
當(dāng)記錄行號(hào)除以2余 1,就跳過當(dāng)前行。下面的print NR,$0也不會(huì)執(zhí)行。 下一行開始,程序有開始判斷NR%2 值。這個(gè)時(shí)候記錄行號(hào)是:2 ,就會(huì)執(zhí)行下面語(yǔ)句塊:'print NR,$0'

awk next使用實(shí)例:


復(fù)制代碼
代碼如下:

要求:
文件: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

分析:
分析發(fā)現(xiàn)需要將包含有“web”行進(jìn)行跳過,然后需要將內(nèi)容與下面行合并為一行。
[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在多行合并,以及選擇性輸出方面,非常方便。大家在使用時(shí)候不妨試試。

相關(guān)文章

最新評(píng)論