青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

All about Awk[譯]

All about Awk

All about Awk

1 說明

模式: pattern

動作: action

原文在這里

3 行間距

3.1 行間距加倍

awk '1; { print "" }' filname.ext

它是如何工作的呢? 這一行就是一個awk程序, 每個awk程序都包含一系列的pattern-action語句"pattern {action statements}". 在這個例子中, 一共有兩個語句:"1"和"{print ""}". 在pattern-action語句中, 模式或者動作都可以省略掉. 如果省略模式, 動作會應用于輸入中的每一行. 而省略掉的動作等價于'{print }'. 因此, 這行程序可以轉換為:

awk '1 { print } { print "" }' filname.ext

動作只會應用于匹配模式的行, 也就是說, 模式為真(true). 由于'1'永遠為真, 因此這行程序可以進一步轉換為兩個print語句:

awk '{ print } { print "" }' filname.ext

Awk中的每個print語句都會跟一個ORS-輸出記錄分隔符(Out Record Separator)變量, 默認情況下是一個換行符. 第一個不帶參數的print語句等價與"print $0", 這里$0表示輸入的整行內容.第二個print語句什么都不輸出, 但是由于每個后面都有一個ORS, 因此它實際輸出一個換行. 好了, 現在每一行都變成雙倍間距了.

3.2 另一種行間距加倍的方式

awk 'BEGIN { ORS="\n\n" }; 1' filname.ext

BEGIN是一個特殊的模式, 它不是用來匹配輸入. 而是在任何輸入被讀入之前執行. 這行程序通過將ORS設定為兩個換行來使文件間隔加倍. 就像我在前面提到過的, 語句"1"會被轉換為"{print}", 并且每個print語句都會以ORS變量作為結尾.

3.3 使文件行間距加倍, 并且兩行文本之間不會有多于一行的空行.

awk 'NF { print $0 "\n" }' filname.ext

這個單行程序使用另一個特殊的變量:NF-Number of Fields. 它保存當前行被分割后的字段數. 例如, "this is a test"被分割為4部分, 因此NF的值為4. 空行""不能被分割為任何片段, 這時NF的值為0. 使用NF作為模式可以有效的過濾空行. 這個單行程序的意思是:如果包含任意數目的字段, 則將整行內容輸出, 然后再輸出一個換行.

3.4 使行間距增加兩倍.

awk '1; { print "\n" }' filname.ext

這個單行程序跟上一個很類似. '1'被轉換為'{ print }', 轉換后的結果為:

awk '{ print; print "\n" }' filname.ext

它輸出一行的內容, 然后輸出一個換行, 后面再跟一個ORS, 默認情況下ORS也是一個換行.

4 計數和計算

4.1 單獨為每個文件的行計數.

awk '{ print FNR "\t" $0 }' filname.ext

這個Awk程序在每行前面添加FNR–File Line Number–和一個tab(\t).FNR變量單獨保存每個文件的當前行行號. 例如, 如果用這個單行程序處理兩個文件,其中一個有10行,另一個12行, 那么它會從1到10 給第一個文件的各行編號, 然后重新從1開始, 將第二個文件的各行依次編號為1到12. 也就是說在處理兩個文件中間, FNR會被重置.

4.2 給所有文件的行計數.

awk '{ print NR "\t" $0 }' filname.ext

這個程序跟上一個的唯一不同在于:這兒用的是NR(Line Number)變量, 它在文件之間不會被重置. 它會為輸入的所有行計數. 例如, 如果用這個程序來處理上個例子中的兩個文件, 它會將文件中的行依次編號為1到22(10+12).

4.3 用精心設計的方式計數.

awk '{ printf("%5d : %s\n", NR, $0) }' filname.ext

這個單行程序使用printf()函數來以定制的格式計數. 它就像我們常見的printf()函數一樣帶有格式參數. 注意printf()輸出的時候并不會附加ORS, 因此我們必須顯式地輸出換行符(\n). 這個程序以右對齊的方式輸出行號, 后面跟一個空格和分號, 然后是輸入行.

4.4 只對文件中的非空行計數.

awk 'NF { $0=++a " :" $0 }; { print }' filname.ext

Awk變量是動態的, 它們產生于第一次被使用的時候. 這個單行程序中, 當輸入行非空的時候, 先將a加1, 然后將a的值添加到當前行的前面一起輸出.

4.5 計算文件行數(模擬wc -l)

awk 'END { print NR }' filname.ext

END是另一個不會匹配輸入行的模式. 它在所有輸入都處理完之后執行. 這個單行程序在處理完所有輸入之后輸出NR的值. NR中保存處理的總行數.

4.6 輸出每行中各個字段的和.

awk '{ s = 0; for (i = 1; i <= NF; i++) s = s+$i; print s }' filname.ext

Awk有一些C語言的特征, 例如for(;;) {…}循環. 這個單行程序循環處理輸入行的各個字段(一行中有NF個字段), 將各個字段的值加到變量's'. 然后將累計值s輸出, 接著再處理下一行.

4.7 輸出所有行中各個字段的和.

awk '{ for (i = 1; i <= NF; i++) s = s+$i }; END { print s }' filname.ext

這個程序跟4.6中的差不多, 區別在于它輸出所有字段的和. 要注意它是怎樣沒有將變量's'初始化為0. 由于變量是動態產生的, 因此不需要初始化.

4.8 將每個字段替換為它的絕對值.

awk '{ for (i = 1; i &lt;= NF; i++) if ($i &lt; 0) $i = -$i; print }' filname.ext

這個單行程序使用了兩個其他的C語言特性, 也就是if(…){…}語句和省略花括號. 它循環處理一行輸入的所有字段, 檢查是否有字段的值小于0. 如果有字段的值小于0, 就對其取反, 是字段值變為正數. 字段可以通過一個變量間接的訪問. 例如, i=5; $i='hello', 將第五個字段的值置為'hello'.下面是重寫過的程序, 跟上面的相同, 不過為了清晰起見添加了花括號. 在每行輸入的所有字段都被它們的絕對值替換之后, 'print'語句就會執行.

awk '{for (i = 1; i <= NF; i++) {if ($i < 0) {$i = -$i;}}print}' filname.ext

4.9 記錄輸入文件中所有字段的數目.

awk '{ total = total + NF }; END { print total }' filname.ext

這個單行程序匹配所有的輸入行, 并且將每行中的字段數加起來. 已處理過的輸入的字段數會保存在變量total中. 一旦輸入被處理完, 特殊的模式'END{…}'就會被執行, 它會輸出總的字段數.

5 特定行的刪除/輸出

5.1 輸出包含單詞"Beth"的行的總行數.

awk 'Beth { n++ }; END { print n+0 }' filname.ext

這個單行程序有兩個pattern-action語句. 第一個是'Beth { n++ }'. 在兩個斜線之間的模式是一個正則表達式. 它匹配所有包含模式"Beth"的行(不一定非得是單詞"Beth", 也可以是"Bethe"或者"theBeth333"). 當某行輸入匹配的時候,變量'n'增加1. 第二個pattern-action語句是'END {print n+0}'. 它在文件處理完之后執行. 注意語句'print n+0'中的'+0'. 在沒有任何輸入行匹配的情況下, 它會強制輸出'0'(此時'n'是未定義的). 假設沒有'+0', 那就會輸出一個空行.

5.2 查找第一個字段的值(數字)最大的行.

awk '$1 > max { max=$1; maxline=$0 }; END { print max, maxline }' filname.ext

這個單行程序始終保存輸入行中第一個字段的最大值(在變量max中)以及相應的行(在變量maxline中). 一旦處理完所有的行, 就將最大值和對應行輸出.

5.3 輸出每行中的字段數, 以及對應的行.

awk '{ print NF ":" $0 } ' filname.ext

這個單行程序僅僅輸出預定義的變量NF-Number of Fields, 它保存輸入行中的字段數, 然后輸出分號和當前行.

5.4 輸出每行的最后一個字段.

awk '{ print $NF }' filname.ext

Awk中的字段不一定非得通過常量引用. 例如, 類似'f=3; print $f'的代碼會輸出第三個字段. 這個單行程序輸出第NF個字段. $NF就是一行中的最后一個字段.

5.5 輸出最后一行的最后一個字段.

awk '{ field = $NF }; END { print field }' filname.ext

這個單行程序始終將最后一個字段的值保存在變量'field'中. 一旦處理完所有的行, 變量field中保存的就是最后一行的最后一個字段, 然后會將它輸出.

5.6 輸出字段數多于4的行.

awk 'NF > 4' filname.ext

這個單行程序省略了action語句. 就像我在3.1中提到的, 省略的action語句等價于'{print}'.

5.7 輸出最后一個字段的值大于4的行.

awk '$NF > 4' filname.ext

這個單行程序跟5.4類似. 它通過NF引用最后一個字段. 如果它大于4, 則將它輸出.

Date: 2008/12/10 11:09:39

posted on 2008-12-10 11:11 季陽 閱讀(1361) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2008年2月>
272829303112
3456789
10111213141516
17181920212223
2425262728291
2345678

導航

統計

常用鏈接

留言簿(2)

隨筆檔案(12)

搜索

最新隨筆

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            午夜精品婷婷| 久久午夜精品一区二区| 欧美性一区二区| 国产精品99久久不卡二区| 欧美一级大片在线免费观看| 国产精品永久入口久久久| 欧美影院成年免费版| 免费试看一区| 中日韩在线视频| 国产欧美一区二区精品性| 久久精品国产免费看久久精品| 噜噜噜躁狠狠躁狠狠精品视频| 亚洲精品国产精品久久清纯直播| 欧美精品在线一区二区| 亚洲一区在线播放| 欧美mv日韩mv亚洲| 亚洲午夜羞羞片| 国内视频精品| 欧美日韩国产丝袜另类| 亚洲综合激情| 欧美激情精品久久久久久久变态| 在线亚洲欧美视频| 一区在线播放| 欧美午夜精品久久久久久人妖| 午夜一区二区三视频在线观看| 欧美成人一区二区三区片免费| 一区二区三区精密机械公司 | 国产精品久久久久久久久久尿 | 欧美国产日韩一区二区在线观看 | 蜜桃久久精品乱码一区二区| 亚洲裸体在线观看| 国产老女人精品毛片久久| 欧美18av| 午夜久久久久久久久久一区二区| 亚洲国产精品久久久久婷婷老年 | 欧美激情导航| 欧美在线短视频| 99av国产精品欲麻豆| 久久天天狠狠| 亚洲欧美日韩国产综合在线| 亚洲精品日韩一| 国产综合色在线视频区| 欧美午夜不卡视频| 欧美成人免费全部| 久久不射电影网| 在线亚洲+欧美+日本专区| 亚洲国产高清一区二区三区| 久久精品国产99精品国产亚洲性色 | 巨胸喷奶水www久久久免费动漫| 亚洲一区二区在线| 99精品视频网| 亚洲人体偷拍| 亚洲国产一区二区在线| 黄色成人小视频| 国产女精品视频网站免费| 欧美日韩日本视频| 欧美精品1区2区| 欧美成年人网| 麻豆精品网站| 久久中文欧美| 久久亚洲精选| 久久视频一区| 久久综合电影一区| 久久久91精品国产一区二区精品| 性伦欧美刺激片在线观看| 亚洲视频免费在线观看| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 午夜综合激情| 香蕉久久精品日日躁夜夜躁| 亚洲一区三区视频在线观看| 99精品免费| 夜夜爽av福利精品导航| 一本大道久久a久久精二百| 亚洲精品日产精品乱码不卡| 亚洲精品免费网站| 亚洲免费成人av电影| 亚洲清纯自拍| 日韩视频一区二区| 中日韩视频在线观看| 亚洲一卡久久| 亚洲欧美一区二区激情| 欧美影院视频| 久久精品国产久精国产爱| 久久精品女人天堂| 美国成人毛片| 欧美护士18xxxxhd| 亚洲青色在线| 亚洲一区二区三区高清不卡| 亚洲自拍偷拍麻豆| 欧美资源在线| 免费一级欧美片在线观看| 欧美精品激情| 国产精品久久国产愉拍| 国产亚洲欧美日韩美女| 136国产福利精品导航| 亚洲精品在线观看免费| 亚洲视频一区二区| 久久成人精品视频| 免费成人毛片| 亚洲精品网址在线观看| 一区二区日韩欧美| 久久精品91| 欧美福利影院| 国产伦精品一区二区三区在线观看 | 亚洲欧美在线另类| 久久精品免费播放| 欧美成人午夜免费视在线看片 | 国产精品视频xxx| 伊人久久亚洲美女图片| 99在线|亚洲一区二区| 午夜精品视频一区| 欧美激情a∨在线视频播放| 亚洲美女视频网| 久久激情综合网| 欧美日韩亚洲综合| 好看的亚洲午夜视频在线| 日韩视频欧美视频| 久久久在线视频| 亚洲精品网址在线观看| 欧美在线视频观看免费网站| 欧美成人福利视频| 国产精品一区二区久久精品 | 日韩一级精品视频在线观看| 欧美在线观看日本一区| 亚洲国产三级在线| 亚洲激情精品| 午夜精品视频网站| 91久久国产综合久久| 午夜在线观看免费一区| 欧美日韩国产精品专区 | 欧美.com| 欧美一区二区三区免费看| 欧美精品午夜| 亚洲高清在线视频| 久久久之久亚州精品露出| 亚洲四色影视在线观看| 欧美mv日韩mv亚洲| 韩国一区二区三区在线观看 | 在线高清一区| 久久精品2019中文字幕| 99综合精品| 欧美激情第1页| 亚洲电影欧美电影有声小说| 欧美亚洲免费| 亚洲无限乱码一二三四麻| 欧美电影免费观看大全| 亚洲国产精品精华液2区45| 久久久久国产免费免费| 性感少妇一区| 国产日韩欧美三级| 欧美一区二视频在线免费观看| 一区二区三区av| 欧美视频在线免费| 亚洲无线观看| 亚洲免费观看在线观看| 欧美精品一区二区三区很污很色的 | 一区二区三区欧美激情| 欧美日韩一卡| 亚洲一区二区三区午夜| 亚洲最快最全在线视频| 欧美人与禽猛交乱配| 日韩亚洲欧美在线观看| 亚洲激情一区二区| 欧美伦理影院| 亚洲性人人天天夜夜摸| 一区二区三区www| 欧美特黄一级大片| 亚洲男人的天堂在线| 一区二区欧美国产| 国产精品老牛| 欧美在线观看一区二区| 欧美亚洲免费在线| 国内精品一区二区三区| 老司机久久99久久精品播放免费 | 美女任你摸久久| 亚洲美女免费视频| 99av国产精品欲麻豆| 国产精品成人免费| 午夜精品美女自拍福到在线| 午夜精品久久久久久99热软件| 国产日韩在线一区| 久久久免费av| 欧美大片免费观看在线观看网站推荐| 亚洲精品久久久久久久久久久| 亚洲国产小视频| 国产精品久久久久免费a∨大胸| 午夜一区二区三区不卡视频| 久久国产欧美精品| 亚洲乱码久久| 亚洲视频碰碰| 影音先锋另类| 亚洲美女毛片| 国产情侣久久| 亚洲国产精品久久久久久女王| 国产精品xxx在线观看www| 久久激情中文| 欧美精品福利在线| 欧美在线啊v| 欧美国产高潮xxxx1819| 午夜精品在线|