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
使用並列格式輸出 

注意!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。



 
粤ICP备14056181号  © 2014-2020 ITdaan.com