sed、locate、find

sed命令:

vim的末行命令(ex模式命令):


sed:Stream EDitor,流編輯器,以行爲單位對一個或多個文件進行編輯處理;每一次sed都會處理給定文件中的一行內容。


在sed處理文本時,將正在處理的當前行存儲到臨時的緩衝區中,稱爲“模式空間”;用當前行去匹配給定的PATTERN,如果能匹配,則使用command編輯處理;如果不匹配,則默認輸出至標準輸出;然後繼續處理下一行,直到文件的末尾。


默認情況下,sed的所有處理行爲不會影響源文件的內容;


我們一般會使用sed命令來自動編輯一個或多個文件,簡化對文件的循環操作;


sed命令:

sed - stream editor for filtering and transforming text

sed [OPTION]... 'script' [input-file]...

常用選項:

-n, --quiet, --silent:對於不能匹配模式的行,默認不輸出到屏幕;

-e script, --expression=script:多條件編輯;

-f script-file, --file=script-file:從指定的script-file中讀取腳本

注意:script-file爲一個能夠定位到腳本文件的路徑,最好爲絕對路徑

-i[SUFFIX], --in-place[=SUFFIX]:原文件直接編輯操作;

-r, --regexp-extended:使sed支持擴展正則表達式;


script:

'AddressesCommand'


Addresses(地址定界):

1.空地址:對所有文件的所有行進行處理;

2.單地址:sed對於能夠匹配該地址的那唯一一行進行處理;

num:表示行號;

/pattern/:能夠匹配該模式的所有行;

$:表示文檔最後一行

3.地址範圍:

addr1,addr2:從addr1開始到addr2結束的中間所有行;

例如:2,8

first~step:從first標記的行號開始,以step所代表的數字爲步長;

例如:1~2, 2~2

addr1,+N:從addr1開始,包括addr1所在行,並繼續向後計算N行;

例如:2,+7相當於2,2+7

addr1,~N:從addr1開始,包括addr1所在行,向後計算addr1*N行;

例如:2,~5相當於2,2*5

/pattern1/,/pattern2/:從被pattern1匹配的第一行開始計算,一直到被/pattern2/匹配到的第一行結束;


Command(處理命令):

=:顯示被模式匹配的行的行號

例如:sed -n '/^$/=' /etc/grub2.cfg

a \text:在被模式匹配的行的後面追加text的內容,支持使用\n換行,從而實現多行追加;

i \text:在被模式匹配的行的前面插入text的內容,支持使用\n換行,從而實現多行插入;

c \text:將被模式匹配的行的修改爲text的內容,支持使用\n換行,從而實現一行變多行;

d:在模式空間中刪除被模式匹配的行;這樣的行不能再進行標準輸出;

注意:在使用d命令的時候,不宜使用-n選項;

p:顯示模式空間中被模式匹配的行;

注意:在使用p命令的時候,通常會搭配-n選項;

w filepath:將模式空間中被模式匹配的行,另存到filepath文件中;

r filepath:將filepath文件的內容追加至模式空間中被模式匹配的行之後;

!Command:在模式空間中被模式匹配的行,不執行Command命令;相反,未被模式匹配的行,參會執行Command命令

s///:查找替換,分隔符可以任意更換,只要相同即可;

s@@@, s###, s,,,

s/pattern/text/[control]

s@/etc/fstab@/etc/mtab@


pattern:計劃查找並替換的內容

text:要替換的結果

control:如何進行替換

g:行內全部替換

p:顯示替換成功的行

w filepath:將替換成功的行另存到filepath文件中;


支持後向引用:

s/\(string\)/&/

s/\(string\)/\1/


高級編輯命令:

h: 把模式空間中的內容覆蓋至保持空間中

H:把模式空間中的內容追加至保持空間中

g: 從保持空間取出數據覆蓋至模式空間

G:從保持空間取出內容追加至模式空間

x: 把模式空間中的內容與保持空間中的內容進行互換

n: 讀取匹配到的行的下一行覆蓋至模式空間

N:追加匹配到的行的下一行至模式空間

d: 刪除模式空間中的行

D:刪除多行模式空間中的所有行


示例:

sed -n 'n;p' FILE

sed '1!G;h;$!d' FILE

sed '$!N;$!D' FILE

sed '$!d' FILE

sed ‘G’ FILE

sed ‘g’ FILE

sed ‘/^$/d;G’ FILE

sed 'n;d' FILE

sed -n '1!G;h;$p' FILE



文件查找:按照文件名或文件屬性來搜索文件;

locate

模糊查找:

基於專用的數據庫進行查找,數據庫應該事先創建,並且定期更新;

可以使用updatedb命令手動更新locate數據庫;

查找速度非常快,查找精確到非常有限;


find

精確查找:

查找精度高,速度略慢;

在指定的位置進行文件名或文件屬性的遍歷掃描;強烈不建議對根目錄進行find操作;

實時查找;

使用find命令只能搜索當前用戶具有讀取和執行權限的目錄;


find命令:

find - search for files in a directory hierarchy

find [OPTIONS...] [查找路徑] [查找條件] [處理動作]

查找路徑:默認爲當前工作目錄,可以指定具體的目錄路徑;

查找條件:進行本次搜索的標準,可以是文件名、文件大小、文件類型、文件權限等等;默認是指定目錄中的所有文件;

處理動作:對於符合條件的文件進行某個處理操作;默認將查找結果輸出到顯示器;


根據文件名查找:

-name 文件名稱,支持使用Globbing,(*, ?, [], [^])

-iname 文件名稱,忽略字母大小寫,支持使用Globbing,(*, ?, [], [^])


根據文件的inode編號查找:

-inum inode編號:通過給定的inode編號查找對應的文件名及路徑;

-samefile name:通過給定的文件名查找對應的inode編號,進而確定所有具有該inode編號的文件名及路徑;

-links n:查找鏈接數爲n的所有文件;


根據正則表達式查找:

-regex pattern:以pattern匹配整個文件路徑字符串,而不僅僅是給定文件的名稱;


根據文件的屬主和屬組進行查找:

-user uname:根據屬主爲指定用戶的用戶名進行查找

-uid UID:根據屬主爲某個UID進行查找

-group gname:

-gid GID:


-nogroup:在文件的屬組上沒有組對應的組名;

-nouser:在文件的屬主上沒有用戶對應的用戶名;


根據文件的類型查找:

-type 文件類型:

b:塊設備

c:字符設備

d:目錄文件

f:普通文件

l:符號鏈接文件

p:管道文件

s:套接字文件

-xtype 文件類型:符號鏈接文件的匹配需要配合其他的選項;


根據時間戳進行查找:

以天爲單位:

-atime [+|-]n:根據訪問時間查找

-ctime [+|-]n:根據改變時間查找

-mtime [+|-]n:根據修改時間查找

n:[n,n+1)

+n:[n+1,+∞)

-n:[now,n)

以分鐘爲單位:

-amin [+|-]n

-cmin [+|-]n

-mmin [+|-]n


例子:

5-28-11-18 

-mtime -3

5-25-11-18

-mtime 3

5-24-11-18

-mtime +3


根據文件的大小進行查找:

-size [+|-]n[cwbkMG]

n:(n-1,n]

-n:[0,n-1]

+n:(n,+∞)


例子:

find -size +2k

當前目錄下所有大於2KB的文件;

find -size 2k

當前目錄下所有1KB-2KB之間的文件;

find -size -2k

當前目錄下所有小於1KB的文件;


組合條件:

-a:邏輯與,默認可以省略;

-o:邏輯或

-not, !:邏輯非


邏輯組合條件遵循德摩根定律:

非(A 與 B) == 非A 或 非B

非(A 或 B) == 非A 與 非B


根據權限查找:

-perm [/|-]mode

mode:精確匹配指定的權限

/mode:隱含了邏輯或的關係,任何一個權限位的權限中只要能有一個權限匹配,即可滿足條件;

-mode:隱含了邏輯與的關係,每一個權限位的權限中都必須同時包含指定權限位,才能滿足條件;


所有都有 取反 任意一個沒有 

! ( a與b與c ) = !a 或 !b 或 !c

所有都沒有 取反 任意一個有

! ( !a與!b與!c ) = a 或 b 或 c


處理動作:

-print:輸出到顯示屏幕,默認的動作;

-ls:對與查找到的結果執行ls -li命令顯示;

-exec COMMAND {} \;:

-ok COMMAND {} \;:

對於查找到的結果執行COMMAND命令;

區別:

-exec是非交互式的;

-ok是交互式的;

{}:佔位符,用來引用被find命令查找到的所有的文件的路徑信息;


-exec和-ok的取代執行操作:

chmod a-r $(find -perm -444 -type f)

find -perm -444 -type f | xargs chmod a-r


注意:管道輸送的是純字符串信息,所以如果管道之後的命令不是處理字符串的命令,需要使用xargs命令將其轉換成能夠被後面命令處理的參數;


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章