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

[文本处理] 批处理怎样根据一个文件的内容查找另一个文件的指定列?

[复制链接]
发表于 2011-7-26 08:35:01 | 显示全部楼层 |阅读模式
有文件1.txt
-176.250000 89.750000
-175.750000 89.750000
-175.250000 89.750000
-174.750000 89.750000
-174.250000 89.750000
和文件2.txt
-179.750000 89.750000 0.936815
-179.250000 89.750000 0.936815
-178.750000 89.750000 0.937381
-178.250000 89.750000 0.937381
-177.750000 89.750000 0.936225
-177.250000 89.750000 0.936225
-176.750000 89.750000 0.925175
-176.250000 89.750000 0.925175
-175.750000 89.750000 0.930261
-175.250000 89.750000 0.930261
-174.750000 89.750000 0.927604
-174.250000 89.750000 0.927604
-173.750000 89.750000 0.915246
-173.250000 89.750000 0.915246
-172.750000 89.750000 0.914859
-172.250000 89.750000 0.914859
-171.750000 89.750000 0.912408
-171.250000 89.750000 0.912408
-170.750000 89.750000 0.914096
-170.250000 89.750000 0.914096
-169.750000 89.750000 0.916220
怎样根据1.txt中的每行数据找到2.txt中对应行的第三列数据并输出到3.txt啊。
  1. @echo off
  2. For /F "tokens=1,2 delims= " %%i In (1.txt) do
  3. ( For /F "tokens=1,2,3 delims= " %%a In (2.txt) do ( if %%a%%b EQU %%i%%j echo %%c) )>>3.txt
  4. pause>nul
复制代码
我自己试写的代码运行不起来,请各位大侠看看怎么回事啊!!!
发表于 2011-7-26 08:43:28 | 显示全部楼层
本帖最后由 bluewing009 于 2011-7-26 08:47 编辑

你好,请注意发帖格式与论坛规则的要求,建议楼主修改一下标题。

详情请见:
http://www.bathome.net/thread-963-1-1.html  第九条
http://www.bathome.net/thread-4054-1-1.html

关于你的问题,请参考findstr命令

评分

参与人数 1PB +4 收起 理由
batman + 4 感谢主动维护论坛秩序

查看全部评分

发表于 2011-7-27 09:40:51 | 显示全部楼层
本帖最后由 saogz 于 2011-7-27 09:44 编辑
  1. @echo off
  2.     for /f "tokens=1,2* delims= " %%i in (1.txt) do (
  3.     findstr /I /c:"%%i %%j" 2.txt >> .tmp
  4.     )
  5.    
  6.     for /f "tokens=3 delims= " %%i in (.tmp) do (
  7.     echo %%i >> 3.txt
  8.     )
  9. del .tmp
  10. pause
复制代码
发表于 2011-7-27 09:59:27 | 显示全部楼层
  1. @echo off
  2.     setlocal enabledelayedexpansion
  3.     for /f "tokens=1,2* delims= " %%i in (1.txt) do (
  4.     for /f "tokens=3 delims= " %%a in ('findstr /I /c:"%%i %%j" 2.txt') do (
  5.     echo %%a >> 3.txt
  6.     )
  7.     )
  8. pause
复制代码
发表于 2011-7-30 23:31:37 | 显示全部楼层
回复 1# lengguoyong


你的代码稍微修改一下即可:
  1. @echo off
  2. (for /f "delims=" %%i in (a.txt) do (
  3.     for /f "tokens=1,2,3 delims= " %%a in (b.txt) do (
  4.         if "%%a %%b" equ "%%i" (
  5.             echo,%%c
  6.         )
  7.     )
  8. ))>c.txt
复制代码
发表于 2011-7-30 23:32:37 | 显示全部楼层
回复 4# saogz


你的findstr不如楼主直接比较的效率高吧
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-17 19:53 , Processed in 0.029788 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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