Provided by: manpages-zh_1.6.3.2-1_all bug

NAME

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

總覽

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

描述

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

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

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

       -行數(一個整數)
              顯示上下文  行數  (一個整數).  這個選項自身沒有指定輸出格式,這是沒有效果的,除非和
              -c 或者 -u 組合使用.  這是已廢置的選項,對於正確的操作, 上下文至少要有兩行。

       -a     所有的文件都視爲文本文件來逐行比較,甚至他們似乎不是文本文件.

       -b     忽略空格引起的變化.

       -B     忽略插入刪除空行引起的變化.

       --brief
              僅報告文件是否相異,在乎差別的細節.

       -c     使用上下文輸出格式.

       -C 行數(一個整數)
       --context[=lines]
              使用上下文輸出格式,顯示以指定 行數 (一個整數), 或者是三行(當 行數 沒有給出時.  對
              於正確的操作, 上下文至少要有兩行.

       --changed-group-format=format
              使用 format 輸出一組包含兩個文件的不同處的行,其格式是 if-then-else .

       -d     改變算法也許發現變化的一個更小的集合.這會使 diff 變慢 (有時更慢).

       -D name
              合併 if-then-else 格式輸出, 預處理宏(由name參數提供)條件.

       -e
       --ed   輸出爲一個有效的 ed 腳本.

       --exclude=pattern
              比較目錄的時候,忽略和目錄中與 pattern(樣式) 相配的.

       --exclude-from=file
              比較目錄的時候,忽略和目錄中與任何包含在 file(文件) 的樣式相配的文件和目錄.

       --expand-tabs
              在輸出時擴展tab爲空格,保護輸入文件的tab對齊方式

       -f     產生一個很象 ed 腳本的輸出,但是但是在他們在文件出現的順序有改變

       -F regexp
              在上下文和統一格式中,對於每一大塊的不同,顯示出匹配 regexp.  的一些前面的行.

       --forward-ed
              產生象 ed 腳本的輸出,但是它們在文件出現的順序有改變。

       -h     這選項現在已沒作用,它呈現Unix的兼容性.

       -H     使用啓發規則加速操作那些有許多離散的小差異的大文件.

       --horizon-lines=lines
              比較給定行數的有共同前綴的最後行,和有共同或綴的最前行.

       -i     忽略大小寫.

       -I regexp
              忽略由插入,刪除行(由regexp 參數提供參考)帶來的改變.

       --ifdef=name
              合併 if-then-else 格式輸出, 預處理宏(由name參數提供)條件.

       --ignore-all-space
              在比較行的時候忽略空白.

       --ignore-blank-lines
              忽略插入和刪除空行

       --ignore-case
              忽略大小寫.

       --ignore-matching-lines=regexp
              忽略插入刪除行(由regexp 參數提供參考).

       --ignore-space-change
              忽略空白的數量.

       --initial-tab
              在文本行(無論是常規的或者格式化的前後文關係)前輸出tab代替空格.  引起的原因是tab對
              齊方式看上去象是常規的一樣.

       -l     產生通過 pr 編碼的輸出.

       -L label
       --label=label
              使用 label 給出的字符在文件頭代替文件名輸出.

       --left-column
              以並列方式印出兩公共行的左邊

       --line-format=format
              使用 format 輸出所有的行,在 if-then-else 格式中.

       --minimal
              改變算法也許發現變化的一個更小的集合.這會使 diff 變慢 (有時更慢).

       -n     輸出 RC-格式 diffs; 除了每條指令指定的行數受影響外 象 -f 一樣。

       -N
       --new-file
              在目錄比較中,如果那個文件只在其中的一個目錄中找到,那麼它被視爲在 另一個目錄中是一
              個空文件.

       --new-group-format=format
              使用 format 以if-then-else 格式輸出只在第二個文件中取出的一個行組

       --new-line-format=format
              使用 format 以if-then-else 格式輸出只在第二個文件中取出的一行

       --old-group-format=format
              使用 format 以if-then-else 格式輸出只在第一個文件中取出的一個行組

       --old-line-format=format
              使用 format 使用 format 以if-then-else 格式輸出只在第一個文件中取出的一行

       -p     顯示帶有c函數的改變.

       -P     在目錄比較中,如果那個文件只在其中的一個目錄中找到,那麼它被視爲在 另一個目錄中是一
              個空文件.

       --paginate
              產生通過 pr 編碼的輸出.

       -q     僅報告文件是否相異,不報告詳細的差異.

       -r     當比較目錄時,遞歸比較任何找到的子目錄.

       --rcs  輸出 RC-格式 diffs; 除了每條指令指定的行數受影響外 象 -f 一樣。

       --recursive
              當比較目錄時,遞歸比較任何找到的子目錄.

       --report-identical-files
       -s     報告兩個文件相同.

       -S file
              當比較目錄時,由 file 開始.  這用於繼續中斷了的比較.

       --sdiff-merge-assist
              打印附加的信息去幫助 sdiff.  sdiff 在運行 diff 時使用這些選項.   這些選項不是特意爲
              使用者直接使用而準備的。

       --show-c-function
              顯示帶有c函數的改變.

       --show-function-line=regexp
              在上下文和統一的格式,對於每一大塊的差別,顯示出匹配 regexp.  的一些前面的行

       --side-by-side
              使用並列的輸出格式.

       --speed-large-files
              使用啓發規則加速操作那些有許多離散的小差異的大文件.

       --starting-file=file
              當比較目錄時,由 file 開始.  這用於繼續中斷了的比較.

       --suppress-common-lines
              在並列格式中不印出公共行。

       -t     在輸出時擴展tab爲空格,保護輸入文件的tab對齊方式

       -T     在文本行(無論是常規的或者格式化的前後文關係)前輸出tab代替空格.引起的原因  是tab對
              齊方式看上去象是常規的一樣.

       --text 所有的文件都視爲文本文件來逐行比較,甚至他們似乎不是文本文件.

       -u     使用統一的輸出格式.

       --unchanged-group-format=format
              使用 format 輸出兩個文件的公共行組,其格式是if-then-else.

       --unchanged-line-format=format
              使用 format 輸出兩個文件的公共行,其格式是if-then-else.

       --unidirectional-new-file
              在目錄比較中,如果那個文件只在其中的一個目錄中找到,那麼它被視爲在 另一個目錄中是一
              個空文件.

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

       -v
       --version
              輸出 diff 版本號.

       -w     在比較行時忽略空格

       -W columns
       --width=columns
              在並列格式輸出時,使用指定的列寬.

       -x pattern
              比較目錄的時候,忽略和目錄中與 pattern(樣式) 相配的.

       -X file
              比較目錄的時候,忽略和目錄中與任何包含在 file(文件) 的樣式相配的文件和目錄.

       -y     使用並列格式輸出

參考

       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