Board logo

标题: 求问一比较替换文件内容的批处理 [打印本页]

作者: keai958     时间: 2010-4-28 17:02    标题: 求问一比较替换文件内容的批处理

两个文本文档:a.txt,b.txt
每个文档中都有两列内容,现在需要比较两个文档中的内容,
方案是以a.txt第二列内容依次去比对b.txt中的第二列内容,如果找到相同的就比较同行的第一列内容,相同则继续,
不同就输出第二列内容到dif.txt,
如果在b.txt中找不到a.txt第二列内容就输入第二列内容到nofind.txt
不知表达明白没有,谢谢
作者: Hanyeguxing     时间: 2010-4-28 17:37
两列?分别以什么为分隔的?不同就输出?输出a的还是b的第二列?你没有具体说明。文本是什么编码?是否含有敏感字符?比较时,是否忽略大小写?
@echo off&setlocal enabledelayedexpansion
for /F "tokens=1*" %%i in (b.txt) do set "@%%j=%%i"
for /F "tokens=1*" %%i in (a.txt) do if defined @%%j (if /i not "%%i"=="!@%%j!" >>dif.txt echo.%%j) else >>nofind.txt echo.%%j
说明:以空格和制表符分隔两个文本,忽略敏感字符问题,编码为ANSI,比较忽略大小写。
作者: keai958     时间: 2010-4-28 19:48


  Quote:
Originally posted by Hanyeguxing at 2010-4-28 05:37 PM:
两列?分别以什么为分隔的?不同就输出?输出a的还是b的第二列?你没有具体说明。文本是什么编码?是否含有敏感字符?比较时,是否忽略大小写 ...

两列中间以tab符隔开吧,嗯,这个可以换成其他分隔。

在我的这个问题里,a和b的第二列是一样的内容,我的问题是:首先在b.txt中查a.txt第二列中的内容,找到后再比对两个文本中第一列内容。

特殊符可能会有下划线,点和@。

明确来说,这两个文本是人名与邮件地址的对应表格,大小写无所谓了,呵呵。
作者: keai958     时间: 2010-4-28 19:55
仔细看了下,大侠的脚本应该能解决我的问题,感谢了。
第二条语句用defined确实让我有一种拨云见日的感觉,呵呵。