我知道有一个类似的帖子:在这里。 我尝试使用它提到的comp命令,但如果我有两个文件,一个具有“abcd”这样的数据,另一个具有“abcde”这样的数据,它只是说文件大小不同。我想知道它们到底有什么不同。在Unix中,简单的diff告诉我哪行和哪列,如果我有“abd”和“abc”之类的东西,windows中的comp命令就可以工作。没有否则。有什么好办法吗?


当前回答

Winmerge有一个命令行实用程序,可能值得一试。

另外,你也可以使用它的图形部分,这取决于你需要什么。

其他回答

DiffUtils可能是你最好的选择。它相当于Windows中的diff。

据我所知,没有内置的等价物。

使用COMP得到错误的原因是该实用程序假定您正在比较的文件具有相同的大小。为了克服这个问题,你可以使用'/n'选项来指定你想要比较的行数。(输入'comp /?在命令行中。 所以你的命令看起来像这样:

C:\>comp "filepath1" "filepath2" /a /l /n=(the number of lines you want to compare) /c 

这应该解决你的问题,如果你想坚持使用COMP。但这将是一个真正的大文件的问题。

虽然comp是一个选择,但我觉得它是原始的,FC是一个更好的选择。如果你经常需要一个文件比较工具,你可以使用FORFILES和FC一起制作一个非常好的文件比较工具。

FC用于ref:

C:\>fc /c(case insensistive) /lbn(number of errors allowed before you wanna stop compare) /n(display line number) "filename1" "filename2"

有很多可用的选项,你可以通过“fc /?” 希望这能有所帮助

另一种选择是从这里下载并安装git。然后,将Git\bin\的路径添加到path变量中。这不仅会给你diff,还会给你许多其他可以从windows命令行使用的linux命令。

您可以通过右键单击“计算机”并选择“属性”来设置PATH变量。然后单击屏幕左侧的“Advanced System Settings”。在弹出窗口中,单击“环境变量”,然后使用Git\bin\在用户变量中添加或更新PATH变量

Git差异文档

Winmerge有一个命令行实用程序,可能值得一试。

另外,你也可以使用它的图形部分,这取决于你需要什么。

在Windows上,我很乐意运行diff和许多其他GNU工具。你可以用cygwin来做,但我个人更喜欢GnuWin32,因为它的安装体验要轻松得多。

所以,我的答案是,Windows中diff的等效程序,正是diff本身!