[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文本处理] [已解决] 批处理比较两个文本的差异

本帖最后由 xudaweb 于 2011-12-8 11:27 编辑

A.txt与B.txt内容仅有数字和字母。
  1. @echo off
  2. fc /c A.txt B.txt
复制代码
忽略大小写比对,如果一样pass,如果不一样直接show出不同之处。
  1. @echo off
  2. cd.>C.txt
  3. for /f "tokens=1* delims=:" %%i in ('findstr /n . A.txt') do (
  4. for /f "tokens=1* delims=:" %%x in ('findstr /n . B.txt') do (
  5. if %%i equ %%x if /i not "%%j"=="%%y" (
  6. >>C.txt echo,%%j --- A.txt
  7. >>C.txt echo,%%y ---B.txt
  8. >>C.txt echo,
  9. )
  10. )
  11. )
复制代码
用上面这段代码,大致可以达到目的,但是不能忽略大小写,即大小写不一致也会显示出来,请教大家如何修改。

加上/i 参数就可以了,就是看着有点不习惯...
  1. if /i not "%%j"=="%%y"
复制代码
1

评分人数

    • CrLf: 感谢给帖子标题标注[已解决]字样PB + 2
学习...

  1. gawk "NR==FNR{a[$0]=$0}NR>FNR{if(a[$0]){print>\"c.txt\"}else{print>\"d.txt\"}}" a.txt b.txt
复制代码
  1. gawk "NR==FNR{a[$0]=$0}NR>FNR{if(a[$0]){print>\"c.txt\"}else{print>\"d.txt\"}}" b.txt a.txt
复制代码
1

评分人数

    • CrLf: 乐于助人PB + 5

TOP

菜鸟学习了,呵呵

TOP

a 行数多于 b,且 b 的最长行不超过 1023 字节时可以这样:
  1. @echo off>c.txt
  2. (for /f "delims=" %%a in ('findstr /n .* a.txt') do (
  3.    set a=%%a
  4.    setlocal enabledelayedexpansion
  5.    set /p b=
  6.    if /i "!a:*:=!" neq "!b!" echo !a!>>a.txt&echo !b!
  7.    endlocal
  8. ))<b.txt>d.txt
复制代码

TOP

  1. @echo off
  2. grep -vxFf a.txt b.txt >c.txt
  3. grep -vxFf b.txt a.txt >d.txt
复制代码

TOP

楼主好像是逐行对比。。。

findstr不适用。

TOP

findstr的话,文件最后要有个换行符。。。

TOP

比较类的命令;REPLACE,FC,FINDSTR暂时就想到这些,其中REPLACE主要用作更新一类
1

评分人数

    • CrLf: 乐于助人PB + 3
枫中残雪:风停了,我的心却在动,让我心中的寒意走向远方

TOP

  1. @echo off
  2. findstr /x /v /g:a.txt b.txt >c.txt
  3. findstr /x /v /g:b.txt a.txt >d.txt
复制代码
1

评分人数

TOP

if /i "%%j" NEQ "%%y"

TOP

回复 1# xudaweb


     if加上参数/i就可以不区分大小写了:if /i %%x==%%y ...
1

评分人数

TOP

if /i 选项
1

评分人数

TOP

返回列表