diff
比較給定的兩個文件的不同
補充說明
diff命令 在最簡單的情況下,比較給定的兩個文件的不同。如果使用“-”代替“文件”參數,則要比較的內容將來自標準輸入。diff命令是以逐行的方式,比較文本文件的異同處。如果該命令指定進行目錄的比較,則將會比較該目錄中具有相同文件名的文件,而不會對其子目錄文件進行任何比較操作。
語法
1diff(選項)(參數)
選項
1-<行數>:指定要顯示多少行的文本。此參數必須與-c或-u參數一併使用;
2-a或--text:diff預設只會逐行比較文本文件;
3-b或--ignore-space-change:不檢查空格字符的不同;
4-B或--ignore-blank-lines:不檢查空白行;
5-c:顯示全部內容,並標出不同之處;
6-C<行數>或--context<行數>:與執行“-c-<行數>”指令相同;
7-d或--minimal:使用不同的演算法,以小的單位來做比較;
8-D<巨集名稱>或ifdef<巨集名稱>:此參數的輸出格式可用於前置處理器巨集;
9-e或--ed:此參數的輸出格式可用於ed的script文件;
10-f或-forward-ed:輸出的格式類似ed的script文件,但按照原來文件的順序來顯示不同處;
11-H或--speed-large-files:比較大文件時,可加快速度;
12-l<字符或字符串>或--ignore-matching-lines<字符或字符串>:若兩個文件在某幾行有所不同,而之際航同時都包含了選項中指定的字符或字符串,則不顯示這兩個文件的差異;
13-i或--ignore-case:不檢查大小寫的不同;
14-l或--paginate:將結果交由pr程序來分頁;
15-n或--rcs:將比較結果以RCS的格式來顯示;
16-N或--new-file:在比較目錄時,若文件A僅出現在某個目錄中,預設會顯示:Only in目錄,文件A 若使用-N參數,則diff會將文件A 與一個空白的文件比較;
17-p:若比較的文件爲C語言的程序碼文件時,顯示差異所在的函數名稱;
18-P或--unidirectional-new-file:與-N類似,但只有當第二個目錄包含了第一個目錄所沒有的文件時,纔會將這個文件與空白的文件做比較;
19-q或--brief:僅顯示有無差異,不顯示詳細的信息;
20-r或--recursive:比較子目錄中的文件;
21-s或--report-identical-files:若沒有發現任何差異,仍然顯示信息;
22-S<文件>或--starting-file<文件>:在比較目錄時,從指定的文件開始比較;
23-t或--expand-tabs:在輸出時,將tab字符展開;
24-T或--initial-tab:在每行前面加上tab字符以便對齊;
25-u,-U<列數>或--unified=<列數>:以合併的方式來顯示文件內容的不同;
26-v或--version:顯示版本信息;
27-w或--ignore-all-space:忽略全部的空格字符;
28-W<寬度>或--width<寬度>:在使用-y參數時,指定欄寬;
29-x<文件名或目錄>或--exclude<文件名或目錄>:不比較選項中所指定的文件或目錄;
30-X<文件>或--exclude-from<文件>;您可以將文件或目錄類型存成文本文件,然後在=<文件>中指定此文本文件;
31-y或--side-by-side:以並列的方式顯示文件的異同之處;
32--help:顯示幫助;
33--left-column:在使用-y參數時,若兩個文件某一行內容相同,則僅在左側的欄位顯示該行內容;
34--suppress-common-lines:在使用-y參數時,僅顯示不同之處。
參數
- 文件1:指定要比較的第一個文件;
- 文件2:指定要比較的第二個文件。
實例
以正常模式比較差異
1diff a.txt b.txt
以上下文 (context) 模式比較差異
1diff -c a.txt b.txt
1 *** a1.txt 2012-08-29 16:45:41.000000000 +0800
2 --- a2.txt 2012-08-29 16:45:51.000000000 +0800
3 ***************
4 *** 1,7 ****
5 a
6 a
7 a
8 !a
9 a
10 a
11 a
12 --- 1,7 ----
13 a
14 a
15 a
16 !b
17 a
18 a
19 a
以聯合 (unified) 模式比較差異
1diff -u a.txt b.txt
1 --- a.txt 2012-08-29 16:45:41.000000000 +0800
2 +++ b.txt 2012-08-29 16:45:51.000000000 +0800
3 @@ -1,7 +1,7 @@
4 a
5 a
6 a
7 -a
8 +b
9 a
10 a
11 a
多文件比較差異
將目錄/usr/li
下的文件"test.txt"與當前目錄下的文件"test.txt"進行比較,輸入如下命令:
1diff /usr/li test.txt #使用diff指令對文件進行比較
上面的命令執行後,會將比較後的不同之處以指定的形式列出,如下所示:
1n1 a n3,n4
2n1,n2 d n3
3n1,n2 c n3,n4
其中,字母"a"、"d"、"c"分別表示添加、刪除及修改操作。而"n1"、"n2"表示在文件1中的行號,"n3"、"n4"表示在文件2中的行號。
注意:以上說明指定了兩個文件中不同處的行號及其相應的操作。在輸出形式中,每一行後面將跟隨受到影響的若干行。其中,以<開始的行屬於文件1,以>開始的行屬於文件2。
來源:https://github.com/jaywcjlove/linux-command
最後修改於: Wednesday, January 31, 2024
版權申明:
- 未標註來源的內容皆為原創,未經授權請勿轉載(因轉載後排版往往錯亂、內容不可控、無法持續更新等);
- 非營利為目的,演繹本博客任何內容,請以'原文出處'或者'參考鏈接'等方式給出本站相關網頁地址(方便讀者)。