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

[文本处理] [已解决]批处理怎样用身份列表在名录库里导出他们的全信息?

本帖最后由 gcbgczhang 于 2021-7-31 22:07 编辑

各位老师
a.txt内容
211281201105302014
21120319581019201X
211203195608142027
………………
b.txt
211203196812032030    张三      34632
211281201105302014    李四      7768
21120319581019201X    麻子      gsdfhs
211203195608142027    呆瓜      gfjhgbv
211203198810092039    弟弟      54654
211281201906102012    表哥      dh879
要求,a.txt中的每一行如果在b.txt找到,则输出b.txt中的这一行累加到c.txt中
我现在用的
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. (for /f %%a in (a.txt) do (
  4.     findstr /c:"%%a" b.csv
  5. ))>c.txt
复制代码
这两文件分别有20万行,搞起来非常慢。有好的方法吗。这样执行是不是两个20万就是400亿,能不能两个文件直接比较的方法?每行部分匹配可以直接比较吗
在线等

回复 1# gcbgczhang

试下看看速度怎么样:
@echo off
(for /f %%a in (a.txt) do for /f "delims=^  tokens=1,*" %%b in ('type "b.txt"^|find "%%a"') do echo,%%b %%c) >.\c.txt
exit

TOP

@qixiaobin0715
现抄现学现用
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /f  %%a in (a.txt) do set #%%a=true
  4. (for /f "tokens=1*" %%b in (b.txt) do if defined #%%b echo;%%b   %%c)>c.txt
  5. pause
复制代码

TOP

回复 3# idwma


    不是只有3列

TOP

回复 4# gcbgczhang


    100列也显示的

TOP

回复 1# gcbgczhang


试试这样能否成功:
  1. findstr /l /g:a.txt b.txt > c.txt
复制代码
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

回复 6# Batcher


    学到了,又去看了下帮助,这个还可以用管道
type a.txt |findstr /g:/ b.txt >c.txt

TOP

回复  gcbgczhang


试试这样能否成功:
Batcher 发表于 2021-7-31 18:40



    管理员牛!!!!!!
这段代码用时3秒,和我花了1小时弄出来的一个字符了不差。……………。

TOP

回复 6# Batcher


    成功!!!!!!!!!用时3秒,索引文件13万行,全信息库文件22万行
我用的for加finstr,用了1个多小时。其它方案和我这进度差不多。

TOP

返回列表