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

[文本处理] 【已解决】BAT如何按指定规则合并两个文件的内容?

[复制链接]
发表于 2015-12-17 20:47:16 | 显示全部楼层 |阅读模式
combination中是这样的:
ID             ID
D00236        D02487
D00475        D00570
D00848        D02272
D00217        D03182
D00340        D00626

index中是conbination各个ID对应的编号
D00023        1
D00049        2
D00059        3
D00088        4
D00095        5
D00105        6
D00109        7
D00113        8
D00118        9
D00126        10
D00165        11
D00182        12

希望得到最后的文档格式如下,即将conbination中的ID对应的index搜索出来
ID             index             ID                 index
D00236            19             D02487         132
D00475             ..              D00570         ..
D00848                             D02272


灰常感谢!!!!
发表于 2015-12-17 21:51:45 | 显示全部楼层
上传附件之前尽量先压缩一下吧
发表于 2015-12-17 21:55:46 | 显示全部楼层
  1. gawk "NR==FNR{a[$1]=$2}NR>FNR{print $1,a[$1],$2,a[$2]}" index.txt combination.txt > result.txt
复制代码
发表于 2015-12-17 23:41:23 | 显示全部楼层
本帖最后由 pcl_test 于 2015-12-17 23:42 编辑
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /f "tokens=1,2" %%a in ('type "index.txt"') do set #%%a=%%b
  4. (echo;ID     index   ID      index
  5. for /f "tokens=1,2" %%a in ('type "combination.txt"') do (
  6.     if not defined #%%a (set/p=%%a  ~    ) else set/p"=%%a  !#%%a!   "
  7.     if not defined #%%b (echo;%%b  ~) else echo;%%b  !#%%b!
  8. ))<nul>结果.txt
  9. pause
复制代码
 楼主| 发表于 2015-12-18 08:48:31 | 显示全部楼层
回复 4# pcl_test


    代码有效!谢谢大神!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-18 08:58 , Processed in 0.017014 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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