找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 24701|回复: 3

[文本处理] 批处理怎样把两个txt文本前6列数字完全相同的行合并后另存?

[复制链接]
发表于 2015-6-19 01:02:05 | 显示全部楼层 |阅读模式
工作中经常碰到服务器日志文档中,相同ip地址只是端口不一样,我想把它们合并找岀来分析,谢谢大家!

如以下示例;
      对比a.txt文本与b.txt文本,把前6列数字完全相同的行合并后,另存为c.txt文本文件的样式。
a.txt
  1. 01 02 03 04 05 06 55
  2. 06 07 08 09 10 11 45
  3. 11 12 13 14 15 16 36
  4. 17 18 19 20 21 22 30
  5. 23 24 25 26 27 28 23
  6. 22 33 44 55 66 77 18
  7. 55 66 69 70 71 72 16
  8. 26 27 28 29 33 34 13
复制代码
b.txt
  1. 01 02 03 04 05 06 2015001
  2. 06 07 08 09 10 11 2015002
  3. 11 12 13 14 15 16 2015003
  4. 17 18 19 20 21 22 2015004
  5. 23 24 25 26 27 28 2015005
  6. 29 30 31 32 33 36 2015006
  7. 01 02 04 05 07 09 2015007
复制代码
c.txt
  1. 01 02 03 04 05 06 55 2015001
  2. 06 07 08 09 10 11 45 2015002
  3. 11 12 13 14 15 16 36 2015003
  4. 17 18 19 20 21 22 30 2015004
  5. 23 24 25 26 27 28 23 2015005
复制代码
发表于 2015-6-19 23:04:44 | 显示全部楼层
  1. @echo off
  2. for /f "tokens=1-6*" %%1 in (a.txt) do set "%%1#%%2#%%3#%%4#%%5#%%6=%%7"
  3. for /f "tokens=1-6*" %%1 in (b.txt) do if defined %%1#%%2#%%3#%%4#%%5#%%6 set "##%%1 %%2 %%3 %%4 %%5 %%6=%%7"
  4. (for /f "tokens=1-6* delims=#=" %%1 in ('set ##') do echo %%1 %%2 %%3 %%4 %%5 %%6 %%7)>$c.txt
  5. pause
复制代码
 楼主| 发表于 2015-6-20 10:46:51 | 显示全部楼层
bailong360 大侠你好!
  经测试得到的c.txt文本如下;它只找出了两个文本前6列相同的行,没有把a.txt中第7列数与b.txt中第7列数合并,麻烦你再看一下要修改哪里?谢谢!
  1. 01 02 03 04 05 06 2015001     
  2. 06 07 08 09 10 11 2015002     
  3. 11 12 13 14 15 16 2015003     
  4. 17 18 19 20 21 22 2015004     
  5. 23 24 25 26 27 28 2015005     
复制代码
发表于 2015-6-22 13:23:15 | 显示全部楼层
回复 3# hkldd
2楼3行改:
  1. for /f "tokens=1-6*" %%1 in (b.txt) do if defined %%1#%%2#%%3#%%4#%%5#%%6 set "##%%1 %%2 %%3 %%4 %%5 %%6=!%%1#%%2#%%3#%%4#%%5#%%6! %%7"
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-18 22:41 , Processed in 0.019752 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表