diff命令能够比较给定的两个文件的不同,如果使用-代替文件参数,则要比较的内容将来自标准输入,diff命令是以逐行的方式比较文本文件的异同处,如果该命令指定进行目录的比较,则将会比较该目录中具有相同文件名的文件,而不会对其子目录文件进行任何比较操作。
-a或--text: diff预设只会逐行比较文本文件。-b或--ignore-space-change: 不检查空格字符的不同。-B或--ignore-blank-lines: 不检查空白行。-c: 显示全部内容,并标出不同之处。-C <line>或--context <line>: 与执行-c-<line>指令相同。-d或--minimal: 使用不同的演算法,以小的单位来做比较。-D <macro>或ifdef <macro>: 此参数的输出格式可用于前置处理器巨集。-e或--ed: 此参数的输出格式可用于ed的script文件。-f或-forward-ed: 输出的格式类似ed的script文件,但按照原来文件的顺序来显示不同处。-H或--speed-large-files: 比较大文件时,可加快速度。-l<string>或--ignore-matching-lines<string>: 若两个文件在某几行有所不同,而这几行同时都包含了选项中指定的字符或字符串,则不显示这两个文件的差异。-i或--ignore-case: 不检查大小写的不同。-l或--paginate: 将结果交由pr程序来分页。-n或--rcs: 将比较结果以RCS的格式来显示。-N或--new-file: 在比较目录时,若文件A仅出现在某个目录中,预设会显示Only in <folder>,文件A若使用-N参数,则diff会将文件A与一个空白的文件比较。-p: 若比较的文件为C语言的程序码文件时,显示差异所在的函数名称。-P或--unidirectional-new-file: 与-N类似,但只有当第二个目录包含了第一个目录所没有的文件时,才会将这个文件与空白的文件做比较。-q或--brief: 仅显示有无差异,不显示详细的信息。-r或--recursive: 比较子目录中的文件。-s或--report-identical-files: 若没有发现任何差异,仍然显示信息。-S <file>或--starting-file <file>: 在比较目录时,从指定的文件开始比较。-t或--expand-tabs: 在输出时,将tab字符展开。-T或--initial-tab: 在每行前面加上tab字符以便对齐。-u,-U <columns>或--unified=<columns>: 以合并的方式来显示文件内容的不同。-v或--version: 显示版本信息。-w或--ignore-all-space: 忽略全部的空格字符。-W <width>或--width <width>: 在使用-y参数时,指定栏宽。-x <file or folder>或--exclude <file or folder>: 不比较选项中所指定的文件或目录。-X<file>或--exclude-from<file>: 您可以将文件或目录类型存成文本文件,然后在<file>中指定此文本文件。-y或--side-by-side: 以并列的方式显示文件的异同之处。--help: 显示帮助。--left-column: 在使用-y参数时,若两个文件某一行内容相同,则仅在左侧的栏位显示该行内容。--suppress-common-lines: 在使用-y参数时,仅显示不同之处。比较file.txt与file2.txt文件的差异,仅输出不同之处。
比较file.txt与file2.txt文件的差异,并排输出全部内容,|表示前后2个文件内容有不同,<表示后面文件比前面文件少了1行内容,>表示后面文件比前面文件多了1行内容。
比较file.txt与自定义输入内容的差异,输入内容后按Ctrl+D输出EOF标识后结束输入。