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

[文本处理] 【已解决】批处理如何根据指定字符匹配CSV一列数据的该行数据

[复制链接]
发表于 2021-1-26 21:06:49 | 显示全部楼层 |阅读模式
如题,现有一个CSV文件太大,给了一些SN码,SN码对应都在CSV文件中的O列,需要找出这些码所对应的该行数据,提取出来求大神指点
发表于 2021-1-26 21:13:03 | 显示全部楼层
回复 1# w31575801


请把以下两个文件打包压缩传上来我试试:
【现有一个CSV文件】这个文件的前10行内容
【给了一些SN码】这个文件的前3行内容
发表于 2021-1-27 08:26:07 | 显示全部楼层
本帖最后由 qixiaobin0715 于 2021-1-27 09:14 编辑

这样不知行不:
  1. @echo off
  2. set "SN=C3F1052G1 C3F1052G2 C3F1052G3"
  3. findstr "%SN%" a.csv>b.csv
  4. pause
复制代码
 楼主| 发表于 2021-1-27 09:18:16 | 显示全部楼层
回复 2# Batcher
 楼主| 发表于 2021-1-27 09:20:47 | 显示全部楼层
回复 2# Batcher


    Log太大 直接去了一点点 您给看看 比如这一个SN (SN对应的都在O列)找到了之后就把这一行给提取出来  有很多SN,需要批量去查找再提取出来
发表于 2021-1-27 09:39:58 | 显示全部楼层
将sn.xlsx复制到文本文件sn.txt中,一行一个sn码。运行下面代码:
  1. findstr /g:sn.txt log.csv>a.csv
复制代码
发表于 2021-1-27 09:53:46 | 显示全部楼层
回复 4# w31575801


请参考Q-04把test.bat、SN.txt、需要提取的LOG.csv文件保存为ANSI编码:
https://mp.weixin.qq.com/s/6lbb97qUOs1sTyKJfN0ZEQ
  1. @echo off
  2. (for /f "skip=1 delims=" %%i in ('type "SN.txt"') do (
  3.     findstr /c:"%%i" "需要提取的LOG.csv"
  4. ))>"结果.csv"
复制代码
发表于 2021-1-27 10:18:46 | 显示全部楼层
文件太大的话,可以考虑第三方
  1. gawk -F"," "NR==FNR{a[$0]=1};NR!=FNR{if(a[$15]==1)print $0}" SN.txt 需要提取的LOG.csv > result.csv
复制代码
 楼主| 发表于 2021-1-27 10:38:57 | 显示全部楼层
回复 8# WHY


    什么第三方呀
 楼主| 发表于 2021-1-27 22:39:03 | 显示全部楼层
回复 7# Batcher


    大佬,我要找几万个SN,这个处理的好慢呀,怎么能快一点
发表于 2021-1-28 06:49:12 | 显示全部楼层
 楼主| 发表于 2021-1-28 09:20:43 | 显示全部楼层
回复 8# WHY


   下载了gawk双击闪退呀
发表于 2021-1-28 09:21:54 | 显示全部楼层
回复 9# w31575801


8楼用的是 gawk.exe
http://bcn.bathome.net/s/tool/index.html?key=gawk
发表于 2021-1-28 09:22:45 | 显示全部楼层
回复 10# w31575801


    6楼的代码效果如何?
发表于 2021-1-28 09:23:28 | 显示全部楼层
回复 12# w31575801


    不要双击gawk,把它和test.bat放在同一个目录下,再执行test.bat
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-20 21:59 , Processed in 0.041474 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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