Board logo

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

作者: gcbgczhang    时间: 2021-7-31 17:33     标题: [已解决]批处理怎样用身份列表在名录库里导出他们的全信息?

本帖最后由 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亿,能不能两个文件直接比较的方法?每行部分匹配可以直接比较吗
在线等
作者: yakeyun    时间: 2021-7-31 18:03

回复 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
作者: idwma    时间: 2021-7-31 18:06

@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
复制代码

作者: gcbgczhang    时间: 2021-7-31 18:24

回复 3# idwma


    不是只有3列
作者: idwma    时间: 2021-7-31 18:35

回复 4# gcbgczhang


    100列也显示的
作者: Batcher    时间: 2021-7-31 18:40

回复 1# gcbgczhang


试试这样能否成功:
  1. findstr /l /g:a.txt b.txt > c.txt
复制代码

作者: idwma    时间: 2021-7-31 18:56

回复 6# Batcher


    学到了,又去看了下帮助,这个还可以用管道
type a.txt |findstr /g:/ b.txt >c.txt
作者: gcbgczhang    时间: 2021-7-31 22:10

回复  gcbgczhang


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



    管理员牛!!!!!!
这段代码用时3秒,和我花了1小时弄出来的一个字符了不差。……………。
作者: gcbgczhang    时间: 2021-7-31 22:12

回复 6# Batcher


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




欢迎光临 批处理之家 (http://bbs.bathome.net/) Powered by Discuz! 7.2