一次讀取一行文本,按輸入分隔符進行切片,切成多個組成部分,將每片直接保存在內建的變量中,$1,$2,$3....,引用指定的變量,可以顯示指定段,或者多個段。如果需要顯示全部的,需要使用$0來引用。可以對單個片段進行判斷,也可以對所有段進行循環判斷。

成都創新互聯公司是一家企業級云計算解決方案提供商,超15年IDC數據中心運營經驗。主營GPU顯卡服務器,站群服務器,成都移動云計算中心,海外高防服務器,機柜大帶寬租用·托管,動態撥號VPS,海外云手機,海外云服務器,海外服務器租用托管等。
其默認分隔符為空格
awk [options] 'program' FILE......
[options]說明
主要有兩種模式
1、 awk [options] 'scripts' file1,file2.....
在這種模式中,scripts主要是命令的堆砌,命令之間用 分號 分割;對輸入的文本行進行處理,通過命令 print,printf 或是輸出重定向的方式顯示出來,這里經常用到的知識點是:awk的內置變量,以及命令print和printf的使用
2、 awk [options] 'PATTERN{action}' file,file2.....
在這種模式中,最重要的是5種模式和5種action的使用,以及awk的數組的使用和內置函數
其格式化輸出: printf FORMAT,item1,item2....
例子: awk '{printf "%-8s %-8s %-8s %-18s %-22s %-15s\n",$1,$2,$3,$4,$5,$6}' netstat.txt
格式符
修飾符
輸出重定向
awk [option] 'PATTERN{action}' file1,file2....
功能說明:復制文件或目錄
用法:
cp [OPTION]... [-T] SOURCE DEST
cp [OPTION]... SOURCE... DIRECTORY
cp [OPTION]... -t DIRECTORY SOURCE...
補充說明:cp命令用在復制文件或目錄,如同時指定兩個以上的文件或目錄,且最后的目標是一個已經存在的目錄,則它會把前面指定的所有文件或目錄復制到該目錄中。若同時指定多個文件或目錄,而最后的目標并非是一個已存在的目錄,則會出現錯誤信息。
常用參數:
-b或--backup 刪除,覆蓋目標文件之前的備份,備份文件會在字尾加上一個備份字符串。
-f或--force 強行復制文件或目錄,不論目標文件或目錄是否已存在。
-i或--interactive 覆蓋既有文件之前先詢問用戶。
-l或--link 對源文件建立硬連接,而非復制文件。
-r 遞歸處理,將指定目錄下的文件與子目錄一并處理。
-s或--symbolic-link 對源文件建立符號連接,而非復制文件。
-S備份字尾字符串或--suffix=備份字尾字符串 用"-b"參數備份目標文件后,備份文件的字尾會被加上一個備份字符串,預設的備份字尾字符串是符號"~"。
-v或--verbose 顯示指令執行過程。
-t 指定目標文件夾,目標文件夾需存在。
sort 是將文件的每一行作為一個單位,相互比較,比較原則是從首字符向后,依次按照ASCII碼值進行比較,默認將他們按照升序輸出
降序
在輸出中去重
將排序結果輸出到原文件
sort的默認輸出是輸出到標準輸出,如果想把結果輸出到文件,需要 sort file newfile,但是如果想把結果輸出到原文件這樣就不行了,這時就需要 使用sort -o
以數值來排序
sort 默認是按照字符串排序的,這樣就會出現10比3小的情況,sort -n 就可以告訴sort 以整數排序
-t 后面跟 分隔符
-k 后面跟數字,表示用第幾列排序
如 sort -t : -k 2 表示把每行 以:號分割,按照第二列排序
banana:30:5.5
orange:20:3.4
apple:10:2.5
我們可以看到,當baidu 和soho都是100的時候,baidu排在前面,當當前域按照默認規矩,是從第一個域開始進行升序排序,因此baidu排在了sohu前面。
sort 支持 -k 2 -k3這種模式,如果你需要,你可以繼續這么寫下去
你仔細看看,在-k 3后面偷偷加上了一個小寫字母r,r和-r的作用是一樣,你也可以把前面的-n去掉 在r后面加上n,如下
其實-k 選項 功能很強大,語法[ FStart [ .CStart ] ] [ Modifier ] [ , [ FEnd [ .CEnd ] ][ Modifier ] ]
從逗號前后 分為兩大部分,即-k 2,2,是嚴格使用第一個域排序,如果只設置-k 2 其實是按照從第一個域到行尾。逗號分開的每部分又有一個點表示子域,即-k 1.2表示 按照第一個域的第二個字符排序,Modifiers就是我們用到的n和r 如 -k 1.2nr 具體我們看下面的例子。
我們使用了-k 1.2,這就表示對第一個域的第二個字符開始到本域的最后一個字符為止的字符串進行排序。你會發現baidu因為第二個字母是a而名列榜首。sohu和 google第二個字符都是o,但sohu的h在google的o前面,所以兩者分別排在第二和第三。這和之前說到的按照默認的排序規則 是不同的,當第一個域的第二個字符相同時,他不會去按照第一個字符排序,而是按照后面的字符排序,這是因為-k 1.2是對第一個域的第二個字符開始到本域的最后一個字符為止的字符串進行排序。而之前的夸域其實是一種假象。
-u只識別用-k設定的域,發現相同,就將后續相同的行都刪除
但是這時候,卻一行也沒有刪除。原來-u是會權衡所有-k選項,將都相同的才會刪除,只要其中有一級不同都不會輕易刪除的
可以用到b、d、f、i、n 或 r。
其中n和r你肯定已經很熟悉了。
b表示忽略本域的簽到空白符號。
d表示對本域按照字典順序排序(即,只考慮空白和字母)。
f表示對本域忽略大小寫進行排序。
i表示忽略“不可打印字符”,只針對可打印字符進行排序。(有些ASCII就是不可打印字符,比如\a是報警,\b是退格,\n是換行,\r是回車等等)
當前文章:linux每天一命令 linux日常命令
當前地址:http://www.yijiale78.com/article28/hihhjp.html
成都網站建設公司_創新互聯,為您提供品牌網站設計、網站設計公司、服務器托管、網站排名、手機網站建設、網站收錄
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯