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

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

两个文本如下:

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


b.txt文本:
000001
000002
000004


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


输出到c.txt文本里
1

评分人数

回复 1# his
  1. @echo off
  2. (for /f %%a in (b.txt) do (
  3. findstr %%a a.txt
  4. ))>c.txt
复制代码
1

评分人数

    • his: 感谢分享技术 + 1
#&cls&@powershell "Invoke-Expression ([Io.File]::ReadAllText('%~0',[Text.Encoding]::UTF8))" &pause&exit

TOP

  1. @echo off
  2. (for /f %%a in (b.txt) do (
  3. findstr "^%%a," a.txt
  4. ))>c.txt
复制代码
改进了一下,行首数字匹配。防止b.txt的数字太小会紊乱。

TOP

  1. findstr /g:b.txt a.txt>c.txt
复制代码

TOP

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]
复制代码
去学去写去用才有进步。安装python3代码存为xx.py 双击运行或右键用IDLE打开按F5运行

TOP

返回列表