主頁 > 知識(shí)庫 > Linux下用于對比文件的diff命令使用教程

Linux下用于對比文件的diff命令使用教程

熱門標(biāo)簽:高德地圖標(biāo)注在電腦上 軟件電話機(jī)器人 萊蕪移動(dòng)外呼系統(tǒng) 金華呼叫中心外呼系統(tǒng)廠家 柯城手機(jī)地圖如何做地圖標(biāo)注 襄陽地圖標(biāo)注店 申請400電話流程好嗎 小語股票電銷機(jī)器人 杭州電銷機(jī)器人有效果嗎

總覽
diff [選項(xiàng)] 源文件 目標(biāo)文件


描述
在最簡單的情況是, diff 比較兩個(gè)文件的內(nèi)容 (源文件 和 目標(biāo)文件). 文件名可以是 - 由標(biāo)準(zhǔn)輸入設(shè)備讀入的文本. 作為特別的情況是, diff - - 比較一份標(biāo)準(zhǔn)輸入的它自己的拷貝如果 源文件 是一個(gè)目錄和 目標(biāo)文件 不是(目錄), diff 會(huì)比較在 源文件(目錄) 里的文件的中和 目標(biāo)文件同名的(文件), 反過來也一樣. 非目錄文件不能是 -. 如果 源文件 和 目標(biāo)文件 都是目錄, diff 比較兩個(gè)目錄中相應(yīng)的文件,依照字母次序排序;這個(gè)比較是不會(huì)遞歸的,除非給出 -r 或者 --recursive. diff 不把一個(gè)目錄的內(nèi)容看為它是一個(gè)文件來比較。被指定的文件不能是標(biāo)準(zhǔn)的輸入, 因?yàn)闃?biāo)準(zhǔn)的輸入是無名的并且"有一樣的名字的文件"的觀點(diǎn)不適用。 diff 的選項(xiàng)由 -, 開始所以正常地 源文件(名) 和 目標(biāo)文件(名) 不可以用 - 開頭. 然而, -- 可以被它視為保留的即使作為文件名的開頭( they begin with -.)


選項(xiàng)
下面是 GNU所接受的 diff 的所有選項(xiàng)的概要. 大多數(shù)的選項(xiàng)有兩個(gè)相同的名字,一個(gè)是單個(gè)的跟在 - 后面字母, 另一個(gè)是由 -- 引出的長名字. 多個(gè)單字母選項(xiàng)(除非它們產(chǎn)生歧義)能夠組合為單行的命令行語法 -ac 是等同于 -a -c. 長命名的選項(xiàng)能被縮短到他們的名字的任何唯一的前綴. 用 ([ 和 ]) 括起來顯示選項(xiàng)產(chǎn)生歧義的選項(xiàng)
-行數(shù)(一個(gè)整數(shù))
顯示上下文 行數(shù) (一個(gè)整數(shù)). 這個(gè)選項(xiàng)自身沒有指定輸出格式,這是沒有效果的,除非和 -c 或者 -u 組合使用. 這是已廢置的選項(xiàng),對于正確的操作, 上下文至少要有兩行。
-a
所有的文件都視為文本文件來逐行比較,甚至他們似乎不是文本文件.
-b
忽略空格引起的變化.
-B
忽略插入刪除空行引起的變化.
--brief
僅報(bào)告文件是否相異,在乎差別的細(xì)節(jié).
-c
使用上下文輸出格式.
-C 行數(shù)(一個(gè)整數(shù))
 
--context[=lines]
使用上下文輸出格式,顯示以指定 行數(shù) (一個(gè)整數(shù)), 或者是三行(當(dāng) 行數(shù) 沒有給出時(shí). 對于正確的操作, 上下文至少要有兩行.
--changed-group-format=format
使用 format 輸出一組包含兩個(gè)文件的不同處的行,其格式是 if-then-else .
-d
改變算法也許發(fā)現(xiàn)變化的一個(gè)更小的集合.這會(huì)使 diff 變慢 (有時(shí)更慢).
-D name
合并 if-then-else 格式輸出, 預(yù)處理宏(由name參數(shù)提供)條件.
-e
 
--ed
輸出為一個(gè)有效的 ed 腳本.
--exclude=pattern
比較目錄的時(shí)候,忽略和目錄中與 pattern(樣式) 相配的.
--exclude-from=file
比較目錄的時(shí)候,忽略和目錄中與任何包含在 file(文件) 的樣式相配的文件和目錄.
--expand-tabs
在輸出時(shí)擴(kuò)展tab為空格,保護(hù)輸入文件的tab對齊方式
-f
產(chǎn)生一個(gè)很象 ed 腳本的輸出,但是但是在他們在文件出現(xiàn)的順序有改變
-F regexp
在上下文和統(tǒng)一格式中,對于每一大塊的不同,顯示出匹配 regexp. 的一些前面的行.
--forward-ed
產(chǎn)生象 ed 腳本的輸出,但是它們在文件出現(xiàn)的順序有改變。
-h
這選項(xiàng)現(xiàn)在已沒作用,它呈現(xiàn)Unix的兼容性.
-H
使用啟發(fā)規(guī)則加速操作那些有許多離散的小差異的大文件.
--horizon-lines=lines
比較給定行數(shù)的有共同前綴的最后行,和有共同或綴的最前行.
-i
忽略大小寫.
-I regexp
忽略由插入,刪除行(由regexp 參數(shù)提供參考)帶來的改變.
--ifdef=name
合并 if-then-else 格式輸出, 預(yù)處理宏(由name參數(shù)提供)條件.
--ignore-all-space
在比較行的時(shí)候忽略空白.
--ignore-blank-lines
忽略插入和刪除空行
--ignore-case
忽略大小寫.
--ignore-matching-lines=regexp
忽略插入刪除行(由regexp 參數(shù)提供參考).
--ignore-space-change
忽略空白的數(shù)量.
--initial-tab
在文本行(無論是常規(guī)的或者格式化的前后文關(guān)系)前輸出tab代替空格. 引起的原因是tab對齊方式看上去象是常規(guī)的一樣.
-l
產(chǎn)生通過 pr 編碼的輸出.
-L label
 
--label=label
使用 label 給出的字符在文件頭代替文件名輸出.
--left-column
以并列方式印出兩公共行的左邊
--line-format=format
使用 format 輸出所有的行,在 if-then-else 格式中.
--minimal
改變算法也許發(fā)現(xiàn)變化的一個(gè)更小的集合.這會(huì)使 diff 變慢 (有時(shí)更慢).
-n
輸出 RC-格式 diffs; 除了每條指令指定的行數(shù)受影響外 象 -f 一樣。
-N
 
--new-file
在目錄比較中,如果那個(gè)文件只在其中的一個(gè)目錄中找到,那么它被視為在另一個(gè)目錄中是一個(gè)空文件.
--new-group-format=format
使用 format 以if-then-else 格式輸出只在第二個(gè)文件中取出的一個(gè)行組
--new-line-format=format
使用 format 以if-then-else 格式輸出只在第二個(gè)文件中取出的一行
--old-group-format=format
使用 format 以if-then-else 格式輸出只在第一個(gè)文件中取出的一個(gè)行組
--old-line-format=format
使用 format 使用 format 以if-then-else 格式輸出只在第一個(gè)文件中取出的一行
-p
顯示帶有c函數(shù)的改變.
-P
在目錄比較中,如果那個(gè)文件只在其中的一個(gè)目錄中找到,那么它被視為在另一個(gè)目錄中是一個(gè)空文件.
--paginate
產(chǎn)生通過 pr 編碼的輸出.
-q
僅報(bào)告文件是否相異,不報(bào)告詳細(xì)的差異.
-r
當(dāng)比較目錄時(shí),遞歸比較任何找到的子目錄.
--rcs
輸出 RC-格式 diffs; 除了每條指令指定的行數(shù)受影響外 象 -f 一樣。
--recursive
當(dāng)比較目錄時(shí),遞歸比較任何找到的子目錄.
--report-identical-files
 
-s
報(bào)告兩個(gè)文件相同.
-S file
當(dāng)比較目錄時(shí),由 file 開始. 這用于繼續(xù)中斷了的比較.
--sdiff-merge-assist
打印附加的信息去幫助 sdiff. sdiff 在運(yùn)行 diff 時(shí)使用這些選項(xiàng). 這些選項(xiàng)不是特意為使用者直接使用而準(zhǔn)備的。
--show-c-function
顯示帶有c函數(shù)的改變.
--show-function-line=regexp
在上下文和統(tǒng)一的格式,對于每一大塊的差別,顯示出匹配 regexp. 的一些前面的行
--side-by-side
使用并列的輸出格式.
--speed-large-files
使用啟發(fā)規(guī)則加速操作那些有許多離散的小差異的大文件.
--starting-file=file
當(dāng)比較目錄時(shí),由 file 開始. 這用于繼續(xù)中斷了的比較.
--suppress-common-lines
在并列格式中不印出公共行。
-t
在輸出時(shí)擴(kuò)展tab為空格,保護(hù)輸入文件的tab對齊方式
-T
在文本行(無論是常規(guī)的或者格式化的前后文關(guān)系)前輸出tab代替空格.引起的原因是tab對齊方式看上去象是常規(guī)的一樣.
--text
所有的文件都視為文本文件來逐行比較,甚至他們似乎不是文本文件.
-u
使用統(tǒng)一的輸出格式.
--unchanged-group-format=format
使用 format 輸出兩個(gè)文件的公共行組,其格式是if-then-else.
--unchanged-line-format=format
使用 format 輸出兩個(gè)文件的公共行,其格式是if-then-else.
--unidirectional-new-file
在目錄比較中,如果那個(gè)文件只在其中的一個(gè)目錄中找到,那么它被視為在另一個(gè)目錄中是一個(gè)空文件.
-U lines
 
--unified[=lines]
使用前后關(guān)系格式輸出,顯示以指定 行數(shù) (一個(gè)整數(shù)), 或者是三行(當(dāng) 行數(shù) 沒有給出時(shí). 對于正確的操作, 上下文至少要有兩行.
-v
 
--version
輸出 diff 版本號.
-w
在比較行時(shí)忽略空格
-W columns
 
--width=columns
在并列格式輸出時(shí),使用指定的列寬.
-x pattern
比較目錄的時(shí)候,忽略和目錄中與 pattern(樣式) 相配的.
-X file
比較目錄的時(shí)候,忽略和目錄中與任何包含在 file(文件) 的樣式相配的文件和目錄.
-y
使用并列格式輸出


實(shí)例:
假設(shè)我們有兩個(gè)文件(file1 和 file2):

復(fù)制代碼
代碼如下:

$ cat file1
Hi,
Hello,
How are you?
I am fine,
Thank you.


復(fù)制代碼
代碼如下:

$ cat file2
Hello,
Hi,
How are you?
I am fine.

你可以看見兩個(gè)文件有些小的不同?,F(xiàn)在,讓我們看看diff命令如何找出兩者的不同的。

像這樣運(yùn)行diff命令:

復(fù)制代碼
代碼如下:

$ diff file1 file2
1d0
Hi,
2a2
> Hi,
4,5c4
I am fine,
Thank you.
---
> I am fine.

你可以看見diff后面跟了兩個(gè)文件的名字作為命令行的參數(shù),并且它在輸出中生成了差異比較。輸出并不容易理解。理由是,這是被計(jì)算機(jī)使用的而不是為了人類。盡管如此,讓我們一步步解碼輸出:

注意 – 在下面的文本中,file1和file2將被當(dāng)作舊文件和新文件。

復(fù)制代碼
代碼如下:

1d0
Hi,

這里,1d0這一行意味著舊文件的第一行應(yīng)該被刪除(d)以使兩個(gè)文件的第一行同步。舊文件中需要被刪除的行以''標(biāo)記。

復(fù)制代碼
代碼如下:

2a2
> Hi,

這里,2a2行意味著新文件中的第二行應(yīng)該加到舊文件的第二行后。要添加的行顯示在輸出的下一行用'>'標(biāo)記。

復(fù)制代碼
代碼如下:

4,5c4
I am fine,
Thank you.
---
> I am fine.

這里,4,5c4這一行意味著在舊文件中的4到5行現(xiàn)在已被改變并且需要用新文件中的第4行代替。添加和刪除的行分別用'>'和''表示。

那么,來總結(jié)一下,

首先diff命令的第一個(gè)參數(shù)被視為舊文件而第二個(gè)參數(shù)被視為新文件。
像1d0、2a2、4,5c4這種表達(dá)式可以用語法解碼為 [舊文件的行號或者行的范圍][行為][新文件的行號或者行的范圍]。這里的'行為'可以是追加,刪除或者改變替換。
''代表刪除的行,而'>'代表添加的行。
除了文件外,diff命令還可以比較兩個(gè)目錄。讓我們通過一個(gè)例子學(xué)習(xí)。

這里是'new_dir'目錄包含的內(nèi)容:

復(fù)制代碼
代碼如下:

$ ls new_dir/
file file2 frnd frnd1.cpp log1.txt log3.txt log5.txt
file1 file name with spaces frnd1 frnd.cpp log2.txt log4.txt

這是'orig_dir'目錄含有的內(nèi)容:(譯注:原文為and here are the contents of a directory named ‘olddir’ ,其中'olddir'應(yīng)為筆誤。)

復(fù)制代碼
代碼如下:

$ ls orig_dir/
file1 file name with spaces frnd1 frnd.cpp log2.txt log4.txt test
file2 frnd frnd1.cpp log1.txt log3.txt log5.txt

下面是diff命令執(zhí)行后的輸出:

復(fù)制代碼
代碼如下:

$ diff new_dir/ orig_dir/
Only in new_dir/: file
Only in orig_dir/: test

你可以看到當(dāng)diff命令被用來比較這兩個(gè)目錄時(shí),很容易就會(huì)顯示兩個(gè)文件中缺失的文件。

下面是一些在命令行下常用的選項(xiàng):

1. 用 -i 忽略大小寫

如果兩個(gè)文件含有相同的文本但是大小寫不同,diff命令仍會(huì)默認(rèn)報(bào)告它不同。

比如:

復(fù)制代碼
代碼如下:

$ cat file1
HI

$ cat file2
hi

$ diff file1 file2
1c1
HI
---
> hi

你可以看見diff命令在輸出中報(bào)告了大小寫不同。

要去除這個(gè)默認(rèn)行為,使用-i選項(xiàng)。

以下是個(gè)例子:

復(fù)制代碼
代碼如下:

$ diff -i file1 file2

這樣你可以看到?jīng)]有生成輸出,這是當(dāng)兩個(gè)文件相同時(shí)的默認(rèn)行為。

2. 用 -s 選項(xiàng)報(bào)告兩個(gè)文件相同

在例子1的后面,我們看到如果文件相同diff不會(huì)生成報(bào)告。雖然這個(gè)默認(rèn)行為不錯(cuò)但是它仍可能會(huì)造成很大疑惑,特別對于新手而言。因此,如果你像樣diff命令明確地報(bào)告兩個(gè)文件不同,那么就使用-s命令選項(xiàng)。

來舉個(gè)例子:

復(fù)制代碼
代碼如下:

$ diff -is file1 file2
Files file1 and file2 are identical

你可以看到我加了-s選項(xiàng)在后面的例子中,這次diff命令會(huì)明確地報(bào)告兩個(gè)文件是相同的。

3. 使用 -b 忽略空格

另外一個(gè)常用的是diff報(bào)告文件存在不同數(shù)量的空格。

舉例說明:

復(fù)制代碼
代碼如下:

$ cat file1
Hi, how are you?

$ cat file2
Hi, how are you?

觀察這兩個(gè)文件唯一的不同是file2中'are'和'you'之間額外的空格。現(xiàn)在,當(dāng)使用diff命令比較兩個(gè)文件時(shí),輸出如下:

復(fù)制代碼
代碼如下:

$ diff file1 file2
1c1
Hi, how are you?
---
> Hi, how are you?

因此你可以看到diff命令報(bào)告了不同。但是如果你想要忽略這些空格,使用 -b 選項(xiàng)。

復(fù)制代碼
代碼如下:

$ diff -b file1 file2

這樣你可以看到由于-b選項(xiàng),diff命令報(bào)告這兩個(gè)文件是相同的。

標(biāo)簽:鶴壁 海北 威海 欽州 天門 景德鎮(zhèn) 黔南 河南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Linux下用于對比文件的diff命令使用教程》,本文關(guān)鍵詞  Linux,下,用于,對比,文件,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Linux下用于對比文件的diff命令使用教程》相關(guān)的同類信息!
  • 本頁收集關(guān)于Linux下用于對比文件的diff命令使用教程的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章