标题: [文本处理] [已解决] 批处理比较两个文本的差异 [打印本页]
作者: xudaweb 时间: 2011-12-8 09:19 标题: [已解决] 批处理比较两个文本的差异
本帖最后由 xudaweb 于 2011-12-8 11:27 编辑
A.txt与B.txt内容仅有数字和字母。- @echo off
- fc /c A.txt B.txt
复制代码
忽略大小写比对,如果一样pass,如果不一样直接show出不同之处。- @echo off
- cd.>C.txt
- for /f "tokens=1* delims=:" %%i in ('findstr /n . A.txt') do (
- for /f "tokens=1* delims=:" %%x in ('findstr /n . B.txt') do (
- if %%i equ %%x if /i not "%%j"=="%%y" (
- >>C.txt echo,%%j --- A.txt
- >>C.txt echo,%%y ---B.txt
- >>C.txt echo,
- )
- )
- )
复制代码
用上面这段代码,大致可以达到目的,但是不能忽略大小写,即大小写不一致也会显示出来,请教大家如何修改。
加上/i 参数就可以了,就是看着有点不习惯...复制代码
作者: slore 时间: 2011-12-8 09:34
if /i 选项
作者: BS0小陈 时间: 2011-12-8 09:35
回复 1# xudaweb
if加上参数/i就可以不区分大小写了:if /i %%x==%%y ...
作者: slore 时间: 2011-12-8 09:51
if /i "%%j" NEQ "%%y"
作者: awk 时间: 2011-12-8 09:54
- @echo off
- findstr /x /v /g:a.txt b.txt >c.txt
- findstr /x /v /g:b.txt a.txt >d.txt
复制代码
作者: wc726842270 时间: 2011-12-8 10:18
比较类的命令;REPLACE,FC,FINDSTR暂时就想到这些,其中REPLACE主要用作更新一类
作者: slore 时间: 2011-12-8 10:49
findstr的话,文件最后要有个换行符。。。
作者: slore 时间: 2011-12-8 11:13
楼主好像是逐行对比。。。
findstr不适用。
作者: awk 时间: 2011-12-8 11:27
- @echo off
- grep -vxFf a.txt b.txt >c.txt
- grep -vxFf b.txt a.txt >d.txt
复制代码
作者: CrLf 时间: 2011-12-8 18:52
a 行数多于 b,且 b 的最长行不超过 1023 字节时可以这样:- @echo off>c.txt
- (for /f "delims=" %%a in ('findstr /n .* a.txt') do (
- set a=%%a
- setlocal enabledelayedexpansion
- set /p b=
- if /i "!a:*:=!" neq "!b!" echo !a!>>a.txt&echo !b!
- endlocal
- ))<b.txt>d.txt
复制代码
作者: 零度深蓝 时间: 2011-12-9 01:28
菜鸟学习了,呵呵
作者: awk 时间: 2011-12-9 09:52
- gawk "NR==FNR{a[$0]=$0}NR>FNR{if(a[$0]){print>\"c.txt\"}else{print>\"d.txt\"}}" a.txt b.txt
复制代码
- gawk "NR==FNR{a[$0]=$0}NR>FNR{if(a[$0]){print>\"c.txt\"}else{print>\"d.txt\"}}" b.txt a.txt
复制代码
欢迎光临 批处理之家 (http://bathome.net./) |
Powered by Discuz! 7.2 |