【Linux基础】 diff命令的参数详解和实例
diff命令參數:
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
使用并列格式輸出
?
?
實例:
有這樣兩個文件:
程序清單1?:hello.c
#include?
int main(void)
{
? ? char msg[] = "Hello world!";
? ??
? ? puts(msg);
? ? printf("Welcome to use diff commond.\n");
? ??
? ? return 0;? ??
}
程序清單2:hello_diff.c
#include?
#include?
int main(void)
{
? ? char msg[] = "Hello world,fome hello_diff.c";
? ??
? ? puts(msg);
? ? printf("hello_diff.c says,'Here you are,using diff.'\n");
? ??
? ? return 0;? ??
}
我們使用diff命令來查看這兩個文件的不同之處,有一下幾種方便的方法:
1、普通格式輸出:
[root@localhost diff]# diff hello.c hello_diff.c?
1a2
> #include?
5c6
? ?? ? char msg[] = "Hello world,fome hello_diff.c";
8c9
? ?? ? printf("hello_diff.c says,'Here you are,using diff.'\n");
[root@localhost diff]#?
上面的“1a2”表示后面的一個文件"hello_diff.c"比前面的一個文件"hello.c"多了一行
"5c6"表示第一個文件的第5行與第二個文件的第6行有區別
2、并排格式輸出
[root@localhost diff]# diff hello.c hello_diff.c -y -W 130
#include? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ???#include?
? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ???> #include?
int main(void)? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ???int main(void)
{? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?{
? ?? ???char msg[] = "Hello world!";? ?? ?? ?? ?? ?? ?? ?? ???|? ?? ?? ?char msg[] = "Hello world,fome hello_diff.c";
? ?? ???puts(msg);? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?puts(msg);
? ?? ???printf("Welcome to use diff commond.\n");? ?? ?? ?? ? |? ?? ?? ?printf("hello_diff.c says,'Here you are,using diff.'\
? ?? ???return 0;? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ? return 0;
}? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?}
[root@localhost diff]#?
這種并排格式的對比一目了然,可以快速找到不同的地方。
-W選擇可以指定輸出列的寬度,這里指定輸出列寬為130
3、上下文輸出格式
[root@localhost diff]# diff hello.c hello_diff.c -c
*** hello.c? ???2007-09-25 17:54:51.000000000 +0800
--- hello_diff.c? ?? ???2007-09-25 17:56:00.000000000 +0800
***************
*** 1,11 ****
??#include?
??
??int main(void)
??{
!? ?? ? char msg[] = "Hello world!";
??
? ?? ???puts(msg);
!? ?? ? printf("Welcome to use diff commond.\n");
??
? ?? ???return 0;
??}
--- 1,12 ----
??#include?
+ #include?
??
??int main(void)
??{
!? ?? ? char msg[] = "Hello world,fome hello_diff.c";
??
? ?? ???puts(msg);
!? ?? ? printf("hello_diff.c says,'Here you are,using diff.'\n");
??
? ?? ???return 0;
??}
[root@localhost diff]#?
這種方式在開頭兩行作了比較文件的說明,這里有三中特殊字符:
+? ?? ???比較的文件的后者比前著多一行
-? ?? ???比較的文件的后者比前著少一行? ?? ???
!? ?? ???比較的文件兩者有差別的行
4、統一輸出格式
[root@localhost diff]# diff hello.c hello_diff.c -u
--- hello.c? ???2007-09-25 17:54:51.000000000 +0800
+++ hello_diff.c? ?? ???2007-09-25 17:56:00.000000000 +0800
@@ -1,11 +1,12 @@
#include?
+#include?
int main(void)
{
-? ?? ? char msg[] = "Hello world!";
+? ?? ? char msg[] = "Hello world,fome hello_diff.c";
? ?? ???puts(msg);
-? ?? ? printf("Welcome to use diff commond.\n");
+? ?? ? printf("hello_diff.c says,'Here you are,using diff.'\n");
? ?? ???return 0;
}
[root@localhost diff]#?
正如看到的那樣,統一格式的輸出更加緊湊,所以更易于理解,更易于修改。
5、其他
假如你想查看兩個文件是否不同又不想顯示差異之處的話,可以加上-q選項:
[root@localhost diff]# diff hello.c hello_diff.c -q
Files hello.c and hello_diff.c differ
[root@localhost diff]#?另外你還可以提供一些匹配規則來忽略某中差別,可以用?-I regexp
[root@localhost diff]# diff hello.c hello_diff.c -c -I include
*** hello.c? ???2007-09-25 17:54:51.000000000 +0800
--- hello_diff.c? ?? ???2007-09-25 17:56:00.000000000 +0800
***************
*** 2,11 ****
??
??int main(void)
??{
!? ?? ? char msg[] = "Hello world!";
??
? ?? ???puts(msg);
!? ?? ? printf("Welcome to use diff commond.\n");
??
? ?? ???return 0;
??}
--- 3,12 ----
??
??int main(void)
??{
!? ?? ? char msg[] = "Hello world,fome hello_diff.c";
??
? ?? ???puts(msg);
!? ?? ? printf("hello_diff.c says,'Here you are,using diff.'\n");
??
? ?? ???return 0;
??}
[root@localhost diff]#?
這里通過“ -I include”選項來忽略帶有“ include”字樣的行
? ? ? ? ? ? ? ??
? ? ? ? ? ? ? ??
? ? ? ? ? ? ? ??
部分內容來自:http://blog.chinaunix.net/u1/48325/showart_433936.html
http://hi.baidu.com/ilotus_y/blog/item/b94231d6f55a1e2a07088b91.html
?
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的【Linux基础】 diff命令的参数详解和实例的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Samrty技术的 初步了解
- 下一篇: linux 其他常用命令