grep、sed、awk、head、tail、gsub、sub
Awk、sed與grep,俗稱Linux下的三劍客,它們之前有很多相似點,但是同樣也各有各的特色,相似的地方是它們都可以匹配文字,其中sed和awk還可以用於文字編輯,而grep則不具備這個功用。
grep搜尋
sed 修改和編輯文字檔案中某些行
awk 是訪問文字檔案,操縱文字檔案中某些資料
三者都不能後面直接接檔名
grep 檔名
sed 檔名
awk檔名
只有如下才行,才會顯示內容
grep 關鍵字 檔名
sed -n '行數p' 檔名
awk '{print}' 檔名
grep -n表示把結果展示出來後,給每一行加上行號
grep -A表示Print NUM lines of trailing context after matching lines顯示匹配內容和它的後幾行
grep -B表示Print NUM lines of leading context before matching lines顯示匹配內容和它的前幾行
sed -n表示指定的行才會被列出來。在一般 sed 的用法中,所有來自檔案的內容都會被列出到螢幕上。
sed -n '1p' 檔名 #顯示第一行
sed -n '$p' 檔名 #顯示最後一行
sed -n '1,2p' 檔名 #顯示第一行到第二行
sed -n '2,$p' 檔名 #顯示第二行到最後一行
awk -F表示以什麼分隔每行的內容
awk -F "," #表示,逗號分隔
awk -F ";" #表示;分號分隔
awk和{print}在一起表示顯示哪些列,或統計多少列,必須加{},大括號裡面的最後可以有;也可以沒有,沒有什麼影響
awk -F "," '{print $0}' #表示,逗號分隔後,顯示所有列$0 is the whole record
awk -F "," '{print $1}' #表示,逗號分隔後,顯示第1列
awk -F "," '{print $3}' #表示,逗號分隔後,顯示第3列
awk -F "," '{print NF}' #表示,逗號分隔後,這一行總共有多少列
以下兩者沒有區別,顯示所有內容
awk '{print}' 檔名
awk '{print;}' 檔名
head、tail後面可以直接接檔名,表示顯示全部內容
head 檔名 #顯示檔案所有內容
head -1 檔名 #顯示檔案第1行內容
head -2 檔名 #顯示檔案最前面2行內容(不是隻顯示第2行)
tail 檔名 #顯示檔案所有內容
tial -1 檔名 #顯示檔案最後1行內容
tial -2 檔名 #顯示檔案最後2行內容(不是隻顯示倒數第2行)
awk經常和gsub、sub一起使用,作用就是使用它們替換檔案中的內容
sub表示把行裡某列的內容只替換第一個
gsbu表示把行裡某列的內容都替換掉
一般格式為
awk 'sub(/A/,"B")' #表示檔案不分列,所有行中的第一個A全部替換為B
awk -F "分隔符" 'sub(/A/,"B",$N)' #表示檔案分列,第N列中的第一個A替換為B
awk 'gsub(/A/,"B")' #表示檔案不分列,所有行中A的全部替換為B
awk -F "分隔符" 'gsub(/A/,"B",$N)' #表示檔案分列,第N列中A的全部替換為B
實驗如下
[oradbm@plmdba script]$ cat 12
a-1, b, c, 2011-11-22, a:d
b-1, b, c, 2011-11-22, a:d
c-1, b, c, 2011-11-22, a:d
d-1, b, c, 2011-11-22, a:d
gsub發現每一行中的所有-都替換掉了(不分列的情況)
[oradbm@plmdba script]$ cat 12 | awk 'gsub(/-/,"")'
a1, b, c, 20111122, a:d
b1, b, c, 20111122, a:d
c1, b, c, 20111122, a:d
d1, b, c, 20111122, a:d
sub發現每一行中只有第一次出現的-被替換掉了(不分列的情況)
[oradbm@plmdba script]$ cat 12 | awk 'sub(/-/,"")'
a1, b, c, 2011-11-22, a:d
b1, b, c, 2011-11-22, a:d
c1, b, c, 2011-11-22, a:d
d1, b, c, 2011-11-22, a:d
gsub發現第4列所有-都替換掉了(分列的情況)
[oradbm@plmdba script]$ cat 12 | awk -F "," 'gsub(/-/,"",$4)'
a-1 b c 20111122 a:d
b-1 b c 20111122 a:d
c-1 b c 20111122 a:d
d-1 b c 20111122 a:d
sub發現第4列只有第一次出現的-被替換掉了(分列的情況)
[oradbm@plmdba script]$ cat 12 | awk -F "," 'sub(/-/,"",$4)'
a-1 b c 201111-22 a:d
b-1 b c 201111-22 a:d
c-1 b c 201111-22 a:d
d-1 b c 201111-22 a:d
grep搜尋
sed 修改和編輯文字檔案中某些行
awk 是訪問文字檔案,操縱文字檔案中某些資料
三者都不能後面直接接檔名
grep 檔名
sed 檔名
awk檔名
只有如下才行,才會顯示內容
grep 關鍵字 檔名
sed -n '行數p' 檔名
awk '{print}' 檔名
grep -n表示把結果展示出來後,給每一行加上行號
grep -A表示Print NUM lines of trailing context after matching lines顯示匹配內容和它的後幾行
grep -B表示Print NUM lines of leading context before matching lines顯示匹配內容和它的前幾行
sed -n表示指定的行才會被列出來。在一般 sed 的用法中,所有來自檔案的內容都會被列出到螢幕上。
sed -n '1p' 檔名 #顯示第一行
sed -n '$p' 檔名 #顯示最後一行
sed -n '1,2p' 檔名 #顯示第一行到第二行
sed -n '2,$p' 檔名 #顯示第二行到最後一行
awk -F表示以什麼分隔每行的內容
awk -F "," #表示,逗號分隔
awk -F ";" #表示;分號分隔
awk和{print}在一起表示顯示哪些列,或統計多少列,必須加{},大括號裡面的最後可以有;也可以沒有,沒有什麼影響
awk -F "," '{print $0}' #表示,逗號分隔後,顯示所有列$0 is the whole record
awk -F "," '{print $1}' #表示,逗號分隔後,顯示第1列
awk -F "," '{print $3}' #表示,逗號分隔後,顯示第3列
awk -F "," '{print NF}' #表示,逗號分隔後,這一行總共有多少列
以下兩者沒有區別,顯示所有內容
awk '{print}' 檔名
awk '{print;}' 檔名
head、tail後面可以直接接檔名,表示顯示全部內容
head 檔名 #顯示檔案所有內容
head -1 檔名 #顯示檔案第1行內容
head -2 檔名 #顯示檔案最前面2行內容(不是隻顯示第2行)
tail 檔名 #顯示檔案所有內容
tial -1 檔名 #顯示檔案最後1行內容
tial -2 檔名 #顯示檔案最後2行內容(不是隻顯示倒數第2行)
awk經常和gsub、sub一起使用,作用就是使用它們替換檔案中的內容
sub表示把行裡某列的內容只替換第一個
gsbu表示把行裡某列的內容都替換掉
一般格式為
awk 'sub(/A/,"B")' #表示檔案不分列,所有行中的第一個A全部替換為B
awk -F "分隔符" 'sub(/A/,"B",$N)' #表示檔案分列,第N列中的第一個A替換為B
awk 'gsub(/A/,"B")' #表示檔案不分列,所有行中A的全部替換為B
awk -F "分隔符" 'gsub(/A/,"B",$N)' #表示檔案分列,第N列中A的全部替換為B
實驗如下
[oradbm@plmdba script]$ cat 12
a-1, b, c, 2011-11-22, a:d
b-1, b, c, 2011-11-22, a:d
c-1, b, c, 2011-11-22, a:d
d-1, b, c, 2011-11-22, a:d
gsub發現每一行中的所有-都替換掉了(不分列的情況)
[oradbm@plmdba script]$ cat 12 | awk 'gsub(/-/,"")'
a1, b, c, 20111122, a:d
b1, b, c, 20111122, a:d
c1, b, c, 20111122, a:d
d1, b, c, 20111122, a:d
sub發現每一行中只有第一次出現的-被替換掉了(不分列的情況)
[oradbm@plmdba script]$ cat 12 | awk 'sub(/-/,"")'
a1, b, c, 2011-11-22, a:d
b1, b, c, 2011-11-22, a:d
c1, b, c, 2011-11-22, a:d
d1, b, c, 2011-11-22, a:d
gsub發現第4列所有-都替換掉了(分列的情況)
[oradbm@plmdba script]$ cat 12 | awk -F "," 'gsub(/-/,"",$4)'
a-1 b c 20111122 a:d
b-1 b c 20111122 a:d
c-1 b c 20111122 a:d
d-1 b c 20111122 a:d
sub發現第4列只有第一次出現的-被替換掉了(分列的情況)
[oradbm@plmdba script]$ cat 12 | awk -F "," 'sub(/-/,"",$4)'
a-1 b c 201111-22 a:d
b-1 b c 201111-22 a:d
c-1 b c 201111-22 a:d
d-1 b c 201111-22 a:d
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30126024/viewspace-2125311/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- awk sub和gsub區別及用法
- shell 中 grep、sed、awk 命令
- gsub in awk
- 指令碼三兄弟 grep、awk、sed指令碼
- 【shell筆記>命令】grep,sed,awk筆記
- Shell字元操作命令——grep、sed、awk字元
- linux awk sed grep awk 求和平均最大最小Linux
- Linux三劍客grep、awk和sedLinux
- Linux 文字處理工具(grep sed awk )Linux
- 【Shell】sed xargs grep awk的組合用法
- linux三劍客(grep、sed、awk)基本使用Linux
- Linux命令之grep/sed/awk等行轉列Linux
- Linux三劍客Awk、Sed、Grep 命令詳解Linux
- shell指令碼專題-----cat,find,grep,awk,sed(五)指令碼
- Linux 三劍客 Awk、Sed、Grep 命令詳解Linux
- 【Shell】【經驗】awk sed grep find sort常用配搭用法
- cat、tail、head、tee、grep、wc、sort檔案操作和過濾AI
- [Bash] Head and TailAI
- 寶付揭秘Linux支付命令操作之grep、sed、awkLinux
- 效能工具之linux三劍客awk、grep、sed詳解Linux
- 【Linux進階】使用grep、find、sed以及awk進行文字操作Linux
- Linux:管道命令與文字處理三劍客(grep、sed、awk)Linux
- 幾個常用的文字處理shell 命令:find、grep、sort、uniq、sed、awk
- Linux系統中的管道命令、grep命令、sed命令和awk命令Linux
- Linux head和tail命令LinuxAI
- linux 中head tail 命令LinuxAI
- Linux命令4-head / tailLinuxAI
- [linux]sed與awkLinux
- awk sed 用法詳解
- 《sed & awk》讀書筆記之 awk 篇筆記
- 選擇性地檢視檔案的方法 head tail sed 檢視檔案部分內容 (轉)AI
- linux之cat,more,less,head,tailLinuxAI
- Sed&awk筆記之awk篇:快速瞭解Awk(一)筆記
- 如何利用多核CPU來加速你的Linux命令 — awk, sed, bzip2, grep, wc等Linux
- grep sed 大批次替換字串字串
- Linux grep,sed,sort,uniq學習Linux
- Linux 中 awk指令 sub和substr的區別Linux
- 學習sed & awk時做的筆記筆記