返回列表 发帖

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

如题,现有一个CSV文件太大,给了一些SN码,SN码对应都在CSV文件中的O列,需要找出这些码所对应的该行数据,提取出来求大神指点

回复 1# w31575801


请把以下两个文件打包压缩传上来我试试:
【现有一个CSV文件】这个文件的前10行内容
【给了一些SN码】这个文件的前3行内容
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

本帖最后由 qixiaobin0715 于 2021-1-27 09:14 编辑

这样不知行不:
@echo off
set "SN=C3F1052G1 C3F1052G2 C3F1052G3"
findstr "%SN%" a.csv>b.csv
pauseCOPY

TOP

回复 2# Batcher

TOP

回复 2# Batcher


    Log太大 直接去了一点点 您给看看 比如这一个SN (SN对应的都在O列)找到了之后就把这一行给提取出来  有很多SN,需要批量去查找再提取出来

TOP

将sn.xlsx复制到文本文件sn.txt中,一行一个sn码。运行下面代码:
findstr /g:sn.txt log.csv>a.csvCOPY

TOP

回复 4# w31575801


请参考Q-04把test.bat、SN.txt、需要提取的LOG.csv文件保存为ANSI编码:
https://mp.weixin.qq.com/s/6lbb97qUOs1sTyKJfN0ZEQ
@echo off
(for /f "skip=1 delims=" %%i in ('type "SN.txt"') do (
    findstr /c:"%%i" "需要提取的LOG.csv"
))>"结果.csv"COPY
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

文件太大的话,可以考虑第三方
gawk -F"," "NR==FNR{a[$0]=1};NR!=FNR{if(a[$15]==1)print $0}" SN.txt 需要提取的LOG.csv > result.csvCOPY

TOP

回复 8# WHY


    什么第三方呀

TOP

回复 7# Batcher


    大佬,我要找几万个SN,这个处理的好慢呀,怎么能快一点

TOP

TOP

回复 8# WHY


   下载了gawk双击闪退呀

TOP

回复 9# w31575801


8楼用的是 gawk.exe
http://bcn.bathome.net/s/tool/index.html?key=gawk
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

回复 10# w31575801


    6楼的代码效果如何?
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

回复 12# w31575801


    不要双击gawk,把它和test.bat放在同一个目录下,再执行test.bat
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

返回列表