Board logo

标题: [文本处理] 批处理如何找出A文本里跟B文本里每一行不相同的数字 [打印本页]

作者: qzwifi    时间: 2012-5-23 22:51     标题: 批处理如何找出A文本里跟B文本里每一行不相同的数字

本帖最后由 pcl_test 于 2016-7-6 11:41 编辑

例:

a.txt内容为:
01 02 03 04 05 06 07 08 09 10 11 12


b.txt为:
01 02 05 07 08 09 11 12
03 04 06 08 09 10 11 12
01 05 07 08 09 10 11 12


查找a.txt行的数字与b.txt行中有哪些是不相同的,处理出来保存为3.txt
两份文本内容均为升续,a.txt内容为固定一行,b.txt内容为多行,但b.txt行内出现的数字不会大过a.txt行内的数字。


      如:

        a.txt为:  01 02 03 04 05 06 07 08 09 10 11 12
b.txt第一行为: 01 02 05 07 08 09 11 12
那么不相同的是:03 04 06 10


        a.txt为:  01 02 03 04 05 06 07 08 09 10 11 12
b.txt第二行为: 03 04 06 08 09 10 11 12
那么不相同的是:01 02 05 07


        a.txt为:  01 02 03 04 05 06 07 08 09 10 11 12
b.txt第三行为: 01 05 07 08 09 10 11 12
那么不相同的是:02 03 04 06

----------------------------------------------------

a.txt
01 02 03 04 05 06 07 08 09 10 11 12

b.txt
01 02 05 07 08 09 11 12
03 04 06 08 09 10 11 12
01 05 07 08 09 10 11 12

所以a.txt与b.txt不相同的是:

03 04 06 10
01 02 05 07
02 03 04 06

保存为3.txt
作者: apang    时间: 2012-5-23 23:43

本帖最后由 apang 于 2012-5-24 00:03 编辑
  1. @echo off&setlocal enabledelayedexpansion
  2. (for /f "delims=" %%a in (b.txt) do (
  3.   set/p aa=<a.txt
  4.   for %%b in (%%a) do set "aa=!aa:%%b=!"
  5.   for %%c in (!aa!) do set "str=!str! %%c"
  6.   echo,!str:~1!&set str=
  7. ))>3.txt
复制代码

作者: qzwifi    时间: 2012-5-24 00:00

回复 2# apang


    谢谢apang大哥!
作者: 喃喃努努    时间: 2012-5-24 09:33

高手真多啊。
作者: 喃喃努努    时间: 2012-5-24 10:21

回复 2# apang


    弱弱的问一下,“set str=”这个是为了做什么用的呢?




欢迎光临 批处理之家 (http://www.bathome.net/) Powered by Discuz! 7.2