Scroll to navigation

DIFF(1) GNU Tools DIFF(1)

NAME

diff - 找出兩個文件的不同點

總覽

diff [選項] 源文件 目標文件

描述

在最簡單的情況是, diff 比較兩個文件的內容 (源文件目標文件). 文件名可以是 - 由標準輸入設備讀入的文本. 作爲特別的情況是, diff - - 比較一份標準輸入的它自己的拷貝 如果 源文件 是一個目錄和 目標文件 不是(目錄), diff 會比較在 源文件(目錄) 裏的文件的中和 目標文件同名的(文件), 反過來也一樣. 非目錄文件不能是 -.

如果 源文件目標文件 都是目錄, diff 比較兩個目錄中相應的文件, 依照字母次序排序;這個比較是不會遞歸的,除非給出 -r 或者 --recursive. diff 不把一個目錄的內容看爲它是一個文件來比較。被指定的文件不 能是標準的輸入, 因爲標準的輸入是無名的並且"有一樣的名字的文 件"的觀點不適用。 diff 的選項由 -, 開始 所以正常地 源文件(名)目標文件(名) 不可以用 - 開頭. 然而, -- 可以被它視爲保留的即使作爲文件名的開頭( they begin with -.

選項

下面是 GNU所接受的 diff 的所有選項的概要. 大多數的選項有兩個相同的名字,一個是單個的 跟在 - 後面字母, 另一個是由 -- 引出的長名字. 多個單字母選項(除非它們產生歧義)能夠組合爲單行的命令行語法 -ac 是等同於 -a -c. 長命名的選項能被縮短到他們的名字的任何唯一的前綴. 用 ([]) 括起來顯示選項產生歧義的選項

-行數(一個整數)
顯示上下文 行數 (一個整數). 這個選項自身沒有指定輸出格式,這是沒有效果的,除非和 -c 或者 -u 組合使用. 這是已廢置的選項,對於正確的操作, 上下文至少要有兩行。
所有的文件都視爲文本文件來逐行比較,甚至他們似乎不是文本文件.
忽略空格引起的變化.
忽略插入刪除空行引起的變化.
僅報告文件是否相異,在乎差別的細節.
使用上下文輸出格式.

使用上下文輸出格式,顯示以指定 行數 (一個整數), 或者是三行(當 行數 沒有給出時. 對於正確的操作, 上下文至少要有兩行.
使用 format 輸出一組包含兩個文件的不同處的行,其格式是 if-then-else .
改變算法也許發現變化的一個更小的集合.這會使 diff 變慢 (有時更慢).
合併 if-then-else 格式輸出, 預處理宏(由name參數提供)條件.

輸出爲一個有效的 ed 腳本.
比較目錄的時候,忽略和目錄中與 pattern(樣式) 相配的.
比較目錄的時候,忽略和目錄中與任何包含在 file(文件) 的樣式相配的文件和目錄.
在輸出時擴展tab爲空格,保護輸入文件的tab對齊方式
產生一個很象 ed 腳本的輸出,但是但是在他們在文件出現的順序有改變
在上下文和統一格式中,對於每一大塊的不同,顯示出匹配 regexp. 的一些前面的行.
產生象 ed 腳本的輸出,但是它們在文件出現的順序有改變。
這選項現在已沒作用,它呈現Unix的兼容性.
使用啓發規則加速操作那些有許多離散的小差異的大文件.
比較給定行數的有共同前綴的最後行,和有共同或綴的最前行.
忽略大小寫.
忽略由插入,刪除行(由regexp 參數提供參考)帶來的改變.
合併 if-then-else 格式輸出, 預處理宏(由name參數提供)條件.
在比較行的時候忽略空白.
忽略插入和刪除空行
忽略大小寫.
忽略插入刪除行(由regexp 參數提供參考).
忽略空白的數量.
在文本行(無論是常規的或者格式化的前後文關係)前輸出tab代替空格. 引起的原因是tab對齊方式看上去象是常規的一樣.
產生通過 pr 編碼的輸出.

使用 label 給出的字符在文件頭代替文件名輸出.
以並列方式印出兩公共行的左邊
使用 format 輸出所有的行,在 if-then-else 格式中.
改變算法也許發現變化的一個更小的集合.這會使 diff 變慢 (有時更慢).
輸出 RC-格式 diffs; 除了每條指令指定的行數受影響外 象 -f 一樣。

在目錄比較中,如果那個文件只在其中的一個目錄中找到,那麼它被視爲在 另一個目錄中是一個空文件.
使用 format 以if-then-else 格式輸出只在第二個文件中取出的一個行組
使用 format 以if-then-else 格式輸出只在第二個文件中取出的一行
使用 format 以if-then-else 格式輸出只在第一個文件中取出的一個行組
使用 format 使用 format 以if-then-else 格式輸出只在第一個文件中取出的一行
顯示帶有c函數的改變.
在目錄比較中,如果那個文件只在其中的一個目錄中找到,那麼它被視爲在 另一個目錄中是一個空文件.
產生通過 pr 編碼的輸出.
僅報告文件是否相異,不報告詳細的差異.
當比較目錄時,遞歸比較任何找到的子目錄.
輸出 RC-格式 diffs; 除了每條指令指定的行數受影響外 象 -f 一樣。
當比較目錄時,遞歸比較任何找到的子目錄.

報告兩個文件相同.
當比較目錄時,由 file 開始. 這用於繼續中斷了的比較.
打印附加的信息去幫助 sdiff. sdiff 在運行 diff 時使用這些選項. 這些選項不是特意爲使用者直接使用而準備的。
顯示帶有c函數的改變.
在上下文和統一的格式,對於每一大塊的差別,顯示出匹配 regexp. 的一些前面的行

使用並列的輸出格式.
使用啓發規則加速操作那些有許多離散的小差異的大文件.
當比較目錄時,由 file 開始. 這用於繼續中斷了的比較.
在並列格式中不印出公共行。
在輸出時擴展tab爲空格,保護輸入文件的tab對齊方式
在文本行(無論是常規的或者格式化的前後文關係)前輸出tab代替空格.引起的原因 是tab對齊方式看上去象是常規的一樣.
所有的文件都視爲文本文件來逐行比較,甚至他們似乎不是文本文件.
使用統一的輸出格式.
使用 format 輸出兩個文件的公共行組,其格式是if-then-else.
使用 format 輸出兩個文件的公共行,其格式是if-then-else.
在目錄比較中,如果那個文件只在其中的一個目錄中找到,那麼它被視爲在 另一個目錄中是一個空文件.

使用前後關係格式輸出,顯示以指定 行數 (一個整數), 或者是三行(當 行數 沒有給出時. 對於正確的操作, 上下文至少要有兩行.

輸出 diff 版本號.
在比較行時忽略空格

在並列格式輸出時,使用指定的列寬.
比較目錄的時候,忽略和目錄中與 pattern(樣式) 相配的.
比較目錄的時候,忽略和目錄中與任何包含在 file(文件) 的樣式相配的文件和目錄.
使用並列格式輸出

參考

cmp(1), comm(1), diff3(1), ed(1), patch(1), pr(1), sdiff(1).

DIAGNOSTICS

退出狀態爲0意味着沒有差別, 1意味着有一些不同。 2意味很有問題(許多差異)

[中文版維護人]

Scorpio <rawk@chinese.com>

[中文版最新更新]

2000/10/19

《中國Linux論壇man手冊頁翻譯計劃》:

http://cmpp.linuxforum.net

本頁面中文版由中文 man 手冊頁計劃提供。
中文 man 手冊頁計劃:https://github.com/man-pages-zh/manpages-zh

22sep1993 GNU Tools