[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

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

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


灰常感谢!!!!

回复 4# pcl_test


    代码有效!谢谢大神!

TOP

本帖最后由 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
复制代码

TOP

  1. gawk "NR==FNR{a[$1]=$2}NR>FNR{print $1,a[$1],$2,a[$2]}" index.txt combination.txt > result.txt
复制代码

TOP

上传附件之前尽量先压缩一下吧

TOP

返回列表