1 | diff
|
2 | ===
|
3 |
|
4 | 比较给定的两个文件的不同
|
5 |
|
6 | ## 补充说明
|
7 |
|
8 | **diff命令** 在最简单的情况下,比较给定的两个文件的不同。如果使用“-”代替“文件”参数,则要比较的内容将来自标准输入。diff命令是以逐行的方式,比较文本文件的异同处。如果该命令指定进行目录的比较,则将会比较该目录中具有相同文件名的文件,而不会对其子目录文件进行任何比较操作。
|
9 |
|
10 | ### 语法
|
11 |
|
12 | ```shell
|
13 | diff(选项)(参数)
|
14 | ```
|
15 |
|
16 | ### 选项
|
17 |
|
18 | ```shell
|
19 | -<行数>:指定要显示多少行的文本。此参数必须与-c或-u参数一并使用;
|
20 | -a或--text:diff预设只会逐行比较文本文件;
|
21 | -b或--ignore-space-change:不检查空格字符的不同;
|
22 | -B或--ignore-blank-lines:不检查空白行;
|
23 | -c:显示全部内容,并标出不同之处;
|
24 | -C<行数>或--context<行数>:与执行“-c-<行数>”指令相同;
|
25 | -d或--minimal:使用不同的演算法,以小的单位来做比较;
|
26 | -D<巨集名称>或ifdef<巨集名称>:此参数的输出格式可用于前置处理器巨集;
|
27 | -e或--ed:此参数的输出格式可用于ed的script文件;
|
28 | -f或-forward-ed:输出的格式类似ed的script文件,但按照原来文件的顺序来显示不同处;
|
29 | -H或--speed-large-files:比较大文件时,可加快速度;
|
30 | -l<字符或字符串>或--ignore-matching-lines<字符或字符串>:若两个文件在某几行有所不同,而之际航同时都包含了选项中指定的字符或字符串,则不显示这两个文件的差异;
|
31 | -i或--ignore-case:不检查大小写的不同;
|
32 | -l或--paginate:将结果交由pr程序来分页;
|
33 | -n或--rcs:将比较结果以RCS的格式来显示;
|
34 | -N或--new-file:在比较目录时,若文件A仅出现在某个目录中,预设会显示:Only in目录,文件A 若使用-N参数,则diff会将文件A 与一个空白的文件比较;
|
35 | -p:若比较的文件为C语言的程序码文件时,显示差异所在的函数名称;
|
36 | -P或--unidirectional-new-file:与-N类似,但只有当第二个目录包含了第一个目录所没有的文件时,才会将这个文件与空白的文件做比较;
|
37 | -q或--brief:仅显示有无差异,不显示详细的信息;
|
38 | -r或--recursive:比较子目录中的文件;
|
39 | -s或--report-identical-files:若没有发现任何差异,仍然显示信息;
|
40 | -S<文件>或--starting-file<文件>:在比较目录时,从指定的文件开始比较;
|
41 | -t或--expand-tabs:在输出时,将tab字符展开;
|
42 | -T或--initial-tab:在每行前面加上tab字符以便对齐;
|
43 | -u,-U<列数>或--unified=<列数>:以合并的方式来显示文件内容的不同;
|
44 | -v或--version:显示版本信息;
|
45 | -w或--ignore-all-space:忽略全部的空格字符;
|
46 | -W<宽度>或--width<宽度>:在使用-y参数时,指定栏宽;
|
47 | -x<文件名或目录>或--exclude<文件名或目录>:不比较选项中所指定的文件或目录;
|
48 | -X<文件>或--exclude-from<文件>;您可以将文件或目录类型存成文本文件,然后在=<文件>中指定此文本文件;
|
49 | -y或--side-by-side:以并列的方式显示文件的异同之处;
|
50 | --help:显示帮助;
|
51 | --left-column:在使用-y参数时,若两个文件某一行内容相同,则仅在左侧的栏位显示该行内容;
|
52 | --suppress-common-lines:在使用-y参数时,仅显示不同之处。
|
53 | ```
|
54 |
|
55 | ### 参数
|
56 |
|
57 | * 文件1:指定要比较的第一个文件;
|
58 | * 文件2:指定要比较的第二个文件。
|
59 |
|
60 | ### 实例
|
61 |
|
62 | #### 以正常模式比较差异
|
63 |
|
64 | ```shell
|
65 | diff a.txt b.txt
|
66 | ```
|
67 |
|
68 | #### 以上下文 (context) 模式比较差异
|
69 |
|
70 | ```shell
|
71 | diff -c a.txt b.txt
|
72 | ```
|
73 |
|
74 | ```shell
|
75 | *** a1.txt 2012-08-29 16:45:41.000000000 +0800
|
76 | --- a2.txt 2012-08-29 16:45:51.000000000 +0800
|
77 | ***************
|
78 | *** 1,7 ****
|
79 | a
|
80 | a
|
81 | a
|
82 | !a
|
83 | a
|
84 | a
|
85 | a
|
86 | --- 1,7 ----
|
87 | a
|
88 | a
|
89 | a
|
90 | !b
|
91 | a
|
92 | a
|
93 | a
|
94 | ```
|
95 |
|
96 | #### 以联合 (unified) 模式比较差异
|
97 |
|
98 | ```shell
|
99 | diff -u a.txt b.txt
|
100 | ```
|
101 |
|
102 | ```shell
|
103 | --- a.txt 2012-08-29 16:45:41.000000000 +0800
|
104 | +++ b.txt 2012-08-29 16:45:51.000000000 +0800
|
105 | @@ -1,7 +1,7 @@
|
106 | a
|
107 | a
|
108 | a
|
109 | -a
|
110 | +b
|
111 | a
|
112 | a
|
113 | a
|
114 | ```
|
115 |
|
116 | #### 多文件比较差异
|
117 |
|
118 | 将目录`/usr/li`下的文件"test.txt"与当前目录下的文件"test.txt"进行比较,输入如下命令:
|
119 |
|
120 | ```shell
|
121 | diff /usr/li test.txt #使用diff指令对文件进行比较
|
122 | ```
|
123 |
|
124 | 上面的命令执行后,会将比较后的不同之处以指定的形式列出,如下所示:
|
125 |
|
126 | ```shell
|
127 | n1 a n3,n4
|
128 | n1,n2 d n3
|
129 | n1,n2 c n3,n4
|
130 | ```
|
131 |
|
132 | 其中,字母"a"、"d"、"c"分别表示添加、删除及修改操作。而"n1"、"n2"表示在文件1中的行号,"n3"、"n4"表示在文件2中的行号。
|
133 |
|
134 | 注意:以上说明指定了两个文件中不同处的行号及其相应的操作。在输出形式中,每一行后面将跟随受到影响的若干行。其中,以<开始的行属于文件1,以>开始的行属于文件2。
|
135 |
|
136 |
|