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/uid-25324849-id-270254.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM