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

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

[复制链接]
发表于 2021-7-31 17:33:40 | 显示全部楼层 |阅读模式
本帖最后由 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亿,能不能两个文件直接比较的方法?每行部分匹配可以直接比较吗
在线等
发表于 2021-7-31 18:03:56 | 显示全部楼层
回复 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
发表于 2021-7-31 18:06:15 | 显示全部楼层
@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
复制代码
 楼主| 发表于 2021-7-31 18:24:48 | 显示全部楼层
回复 3# idwma


    不是只有3列
发表于 2021-7-31 18:35:14 | 显示全部楼层
回复 4# gcbgczhang


    100列也显示的
发表于 2021-7-31 18:40:45 | 显示全部楼层
回复 1# gcbgczhang


试试这样能否成功:
  1. findstr /l /g:a.txt b.txt > c.txt
复制代码
发表于 2021-7-31 18:56:38 | 显示全部楼层
回复 6# Batcher


    学到了,又去看了下帮助,这个还可以用管道
type a.txt |findstr /g:/ b.txt >c.txt
 楼主| 发表于 2021-7-31 22:10:01 | 显示全部楼层
回复  gcbgczhang


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



    管理员牛!!!!!!
这段代码用时3秒,和我花了1小时弄出来的一个字符了不差。……………。
 楼主| 发表于 2021-7-31 22:12:23 | 显示全部楼层
回复 6# Batcher


    成功!!!!!!!!!用时3秒,索引文件13万行,全信息库文件22万行
我用的for加finstr,用了1个多小时。其它方案和我这进度差不多。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-20 20:50 , Processed in 0.031711 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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