Linux命令日日说(十二)-- diff

diff


语法

diff [options] ... files

一行一行的比较文件,,是不是感觉Torvalds也复用了些什么?


参数

  • -i --ignore-case 忽略文件内容中的大小写差异。

  • --ignore-file-name-case 比较文件名时忽略大小写。

  • --no-ignore-file-name-case 比较文件名时考虑大小写。

  • -b --ignore-space-change 忽略空白字符。

  • -w --ignore-all-space 忽略所有空白。

  • -B --ignore-blank-lines 忽略行全部空白行。

  • -I RE --ignore-matching-lines=RE 忽略所有行都匹配RE(指定字符)的。

  • -a --text 将所有文件视为文本。

  • -c -C NUM --context[=NUM] -C 复制的上下文的输出NUM(默认3)行, -c 输出全部。

  • -u -U NUM --unified[=NUM] -U 输出统一上下文的NUM行(默认为3行),-u 输出全部。

  • --label LABEL 使用LABEL而不是文件名

  • -p --show-c-function 若比较的文件为C语言的程序码文件时,显示差异所在的函数名称。

  • -F RE --show-function-line=RE 显示最近匹配RE(指定字符)的行。

  • -q --brief 仅输出文件是否不同。

  • -e --ed 此参数的输出格式可用于ed的script文件。

  • --normal 仅输出普通的一种比较

  • -n --rcs 将比较结果以RCS的格式来显示。

  • -y --side-by-side 以并列的方式显示文件的异同之处。

  • -W NUM --width=NUM 在使用-y参数时,指定栏宽(默认130)。

  • --left-column 在使用-y参数时,仅指定左边栏宽。

  • --suppress-common-lines 在使用-y参数是,不输出无差别内容行。

  • -D NAME --ifdef=NAME 输出合并文件以显示“#ifdef NAME”差异。

  • -l --paginate 将结果交由pr程序来分页。

  • -t --expand-tabs 展开tab输出为空格。

  • -T --initial-tab 在每行前面加上tab字符以便对齐。

  • -r --recursive 递归地比较找到的任何子目录。

  • -N --new-file 将缺少的文件视为空。

  • --unidirectional-new-file 将缺少的第一个文件视为空。

  • -s --report-identical-files 当两个文件相同时报告。

  • -x PAT --exclude=PAT 不比较选项中所指定的文件或目录。

  • -X FILE --exclude-from=FILE 排除与文件中的任何模式匹配的文件。

  • -S FILE --starting-file=FILE 在比较目录时,从指定的文件开始比较。

  • --from-file=FILE1 将FILE1与所有操作进行比较。FILE1可以是目录。

  • --to-file=FILE2 将所有操作与FILE2进行比较。FILE2可以是目录。

  • -d --minimal 试图寻找较小的改变。

  • --speed-large-files 假设有大文件和许多零散的小更改。

  • -v --version 输出版本信息。

  • --help 输出帮助信息


Example

  • diff file1 file2

    没有任何参数比较两个文件。

    zzw:temp zzw$ diff file1 file2
    1,2c1,2
    < file1
    < a
    ---
    > file2
    > A
    4c4
    < line4
    ---
    > Line4
    zzw:temp zzw$ cat file1
    file1
    a
    line3
    line4
    zzw:temp zzw$ cat file2
    file2
    A
    line3
    Line4
    
  • diff -i file1 file2

    忽略大小写比较

    zzw:temp zzw$ diff -i file1 file2
    1c1
    < file1
    ---
    > file2
    
  • diff -I ine file1 file2

    忽略行中包含了ine的,这里line4Line4的比较就和-i效果一样了

    zzw:temp zzw$ diff -I ine file1 file2
    1,2c1,2
    < file1
    < a
    ---
    > file2
    > A
    
  • diff -u file1 file2

    以合并的方式标识不同,是不是很熟悉。

    zzw:temp zzw$ diff -u file1 file2
    --- file1   2020-03-21 23:56:50.000000000 +0800
    +++ file2   2020-03-21 23:56:59.000000000 +0800
    @@ -1,4 +1,4 @@
    -file1
    -a
    +file2
    +A
     line3
    -line4
    +Line4
    
  • diff -c file1 file2

    标识每行不同,不同的行前面有!

    zzw:temp zzw$ diff -c file1 file2
    *** file1   2020-03-21 23:56:50.000000000 +0800
    --- file2   2020-03-21 23:56:59.000000000 +0800
    ***************
    *** 1,4 ****
    ! file1
    ! a
      line3
    ! line4
    --- 1,4 ----
    ! file2
    ! A
      line3
    ! Line4
    
  • diff -u --label LABEL file1 file2

    使用--label标签后file1的文件名就变成了自定义的LABEL

    zzw:temp zzw$ diff -u --label LABEL file1 file2
    --- LABEL
    +++ file2   2020-03-22 00:57:31.000000000 +0800
    @@ -1,4 +1,4 @@
    -file1
    -a
    +file2
    +A
     line3
    -line4
    +Line4
    
  • diff -w file1 file2

    忽略所有的空白符,第五行添加了一个tab符在file1中.

    zzw:temp zzw$ diff -w file1 file2
    1,2c1,2
    < file1
    < a
    ---
    > file2
    > A
    4c4
    < line4
    ---
    > Line4
    zzw:temp zzw$ cat file1
    file1
    a
    line3
    line4
        line5
    zzw:temp zzw$ cat file2
    file2
    A
    line3
    Line4
    line5
    
  • diff -q file1 file2

    仅仅输出两文件是否不同。

    zzw:temp zzw$ diff -q file1 file2
    Files file1 and file2 differ
    
  • diff -n file1 file2

    zzw:temp zzw$ diff -n file1 file2
    d1 2
    a2 2
    file2
    A
    d4 2
    a5 2
    Line4
    line5
    
  • diff -y file1 file2

    以并列的方式显示,|代表有差别

    zzw:temp zzw$ diff -y file1 file2
    file1                                 | file2
    a                                     | A
    line3                                   line3
    line4                                 | Line4
        line5                             | line5
    
  • diff -y --suppress-common-lines file1 file2

    --suppress-common-lines不会输出line3,因为内容一样。

    zzw:temp zzw$ diff -y --suppress-common-lines file1 file2
    file1                                 | file2
    a                                     | A
    line4                                 | Line4
        line5                             | line5
    
  • diff -s file3 file4

    当两个文件相同是显示信息,否则显示不同。不加-s情形下,两文件想不无任何输出信息。

    zzw:temp zzw$ diff -s file3 file4
    Files file3 and file4 are identical
    
  • diff -v

    输出版本信息。

    zzw:temp zzw$ diff -v
    diff (GNU diffutils) 2.8.1
    Copyright (C) 2002 Free Software Foundation, Inc.
    
    This program comes with NO WARRANTY, to the extent permitted by law.
    You may redistribute copies of this program
    under the terms of the GNU General Public License.
    For more information about these matters, see the file named COPYING.
    
    Written by Paul Eggert, Mike Haertel, David Hayes,
    Richard Stallman, and Len Tower.
    
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,117评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,328评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,839评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,007评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,384评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,629评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,880评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,593评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,313评论 1 243
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,575评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,066评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,392评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,052评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,082评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,844评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,662评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,575评论 2 270

推荐阅读更多精彩内容