grep
作用:文本搜索工具,根據用戶指定的“模式”對目標文本逐行進行匹配檢查;打印匹配到的行
模式:由正則表達式字符及文本字符所編寫的過濾條件
vgrep [OPTIONS] PATTERN [FILE…]
grep root /etc/passwd
grep “$USER” /etc/passwd
grep ‘$USER’ /etc/passwd
grep `whoami` /etc/passwd
命令選項:
–color=auto: 對匹配到的文本著色顯示
-v: 顯示不被pattern匹配到的行
-i: 忽略字符大小寫
-n:顯示匹配的行號
-c: 統計匹配的行數
-o: 僅顯示匹配到的字符串
-q: 靜默模式,不輸出任何信息
-A #: after, 后#行
-B #: before, 前#行
-C #:context, 前后各#行
-e:實現多個選項間的邏輯or關系 grep –e ? ‘cat ’ ? ?-e ? ? ‘dog’ ? ? file
-w:匹配整個單詞
-E:使用ERE
-F:相當于fgrep,不支持正則表達式
命令常見用法:
1:在文件中搜索一個單詞,命令會返回一個包含“match_pattern”的文本行
2:輸出除之外的所有行 -v 選項:
3:只輸出文件中匹配到的部分 -o 選項:
4:輸出包含匹配字符串的行數 -n 選項:
5:grep遞歸搜索文件在多級目錄中對文本進行遞歸搜索:
6:選項 -e 制動多個匹配樣式:
7:在grep搜索結果中包括或者排除指定文件:
8:grep靜默輸出:
? sed
Stream EDitor, 行編輯器
sed是一種流編輯器,它一次處理一行內容。處理時,把當前 處理的行存儲在臨時緩沖區中,稱為“模式空間”(pattern space ),接著用sed命令處理緩沖區中的內容,處理完成后 ,把緩沖區的內容送往屏幕。然后讀入下行,執行下一個循環 。如果沒有使諸如‘D’的特殊命令,那會在兩個循環之間清空 模式空間,但不會清空保留空間。這樣不斷重復,直到文件末 尾。文件內容并沒有改變,除非你使用重定向存儲輸出。
功能:主要用來自動編輯一個或多個文件,簡化對文件的反復 操作,編寫轉換程序等
用法:
sed [option]… ‘script’ inputfile…
常用選項:
-n :不輸出模式空間內容到屏幕,即不自動打印
-e: 多點編輯
-f :/PATH/SCRIPT_FILE : 從指定文件中讀取編輯腳本
-r: 支持使用擴展正則表達式
-i.bak: 備份文件并原處編輯
script:
‘地址命令’ :
1 ? ?不給地址:對全文進行處理
2 ? 單地址:
a: ?#: 指定的行,$ :最后一行
b: ? /pattern/ :被此處模式所能夠匹配到的每一行
地址范圍:
1 ? ? ?#,#
2 ? ?#,+#
3 ? ?/pat1/,/pat2/
#,/pat1/
~ :步進
1: ? ?1~2 奇數行
2: ? ?2~2 偶數行
編輯命令:
d: 刪除模式空間匹配的行,并立即啟用下一輪循環
p :打印當前模式空間內容,追加到默認輸出之后
a [\]text :在指定行后面追加文本,支持使用\n實現多行追加
i [\]text :在行前面插入文本
c [\]text :替換行為單行或多行文本
w /path/somefile: 保存模式匹配的行至指定文件
r /path/somefile :讀取指定文件的文本至模式空間中,匹配到的行后
=: 為模式空間中的行打印行號
!:模式空間中匹配行取反處理
s/// :查找替換,支持使用其它分隔符,s@@@ ,s###
v替換標記:
g: 行內全局替換
p: 顯示替換成功的行
w /PATH/TO/SOMEFILE :將替換成功的行保存至文件中
高級編輯命令
P :打印模式空間開端至\n內容 ,并追加到默認輸出之前
h: 把模式空間中的內容覆蓋至保持空間中
H :把模式空間中的內容追加至保持空間中
g: 從保持空間取出數據覆蓋至模式空間
G :從保持空間取出內容追加至模式空間
x: 把模式空間中的內容與保持空間中的內容進行互換
n: 讀取匹配到的行的下一行覆蓋至模式空間
N :讀取匹配到的行的下一行追加至模式空間
d: 刪除模式空間中的行
D :如果模式空間包含換行符,則刪除直到第一個換行符的模式空間中的文本 ,并不會讀取新的輸入行,而使用合成的模式空間重新啟動循環。如果模式空間不包含換行符,則會像發出
d命令那樣啟動正常的新循環
本文來自投稿,不代表Linux運維部落立場,如若轉載,請注明出處:http://www.www58058.com/89467