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

[文本处理] [已解决]批处理如何根据文本内容找出另个文本含有相同内容的行?

[复制链接]
发表于 2016-3-7 17:10:42 | 显示全部楼层 |阅读模式
两个文本如下:

a.txt文本:
000001,北京张三饭店,早餐
000002,四川馆,午餐
000003,天津发发发,早餐
000004,武汉小食,早餐
000005,武汉小食,晚餐


b.txt文本:
000001
000002
000004


将a和b文本的前面那列数字对比,相同的在b文本里添加a文本数字后面的内容,像这样
000001,北京张三饭店,早餐
000002,四川馆,午餐
000004,武汉小食,早餐


输出到c.txt文本里

评分

参与人数 1PB -2 收起 理由
pcl_test -2 勿发笼统的标题

查看全部评分

发表于 2016-3-7 17:27:43 | 显示全部楼层
回复 1# his
  1. @echo off
  2. (for /f %%a in (b.txt) do (
  3.         findstr %%a a.txt
  4. ))>c.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
his + 1 感谢分享

查看全部评分

发表于 2016-3-7 19:39:00 | 显示全部楼层

  1. @echo off
  2. (for /f %%a in (b.txt) do (
  3.         findstr "^%%a," a.txt
  4. ))>c.txt
复制代码
改进了一下,行首数字匹配。防止b.txt的数字太小会紊乱。
发表于 2016-3-7 20:21:49 | 显示全部楼层
  1. findstr /g:b.txt a.txt>c.txt
复制代码
发表于 2016-3-8 01:54:44 | 显示全部楼层
python
  1. a=open("a.txt").readlines()
  2. b=[r.strip("\n") for r in open("b.txt").readlines()]
  3. with open("c.txt","a+") as f:
  4.         [f.write(r) for r in a if r.split(',')[0] in b]
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-18 02:03 , Processed in 0.019368 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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