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

[文本处理] 批处理提取指定列,遇到空值,不能正确提取,请大家指点,谢谢!

[复制链接]
发表于 2022-10-5 10:23:05 | 显示全部楼层 |阅读模式
提取指定列,遇到空值,不能正确提取,比如,我要提取1.txt的1与3列,以逗号分隔符分割,但是原本第二列有空值的行,去提取第三列就失败了,第二列为空的,第三列工作组不能正确提取,请大家帮帮忙,该如何正确操作,谢谢!
  1. @echo off
  2. for /f "tokens=1,3 delims=," %%i in (in_txt.txt) do (
  3.                 echo %%i,%%j
  4. )>>out_txt.txt
  5. pause&exit
复制代码
in_txt.txt:
姓名,工作时间,工作组
张三,,工作组A
张三,,工作组A
张三,2022-03-01 17:03:06,工作组B
李四,2022-03-01 22:19:28,工作组B
李四,,工作组B
李四,2022-03-02 03:11:26,工作组A

out_txt.txt
姓名,工作组
张三,
张三,
张三,工作组B
李四,工作组B
李四,
李四,工作组A

工作组不应有空白啊???
发表于 2022-10-5 14:12:31 | 显示全部楼层
  1. for /f "tokens=1,2,3 delims=," %%i in (in_txt.txt) do (
  2.   echo %%j|findstr /i "工作组"&&echo %%i,%%j>>out_txt.txt || echo %%i,%%k>>out_txt.txt
  3. )
复制代码
这个现象我也奇怪,道理不明白,所以本回答仅作为解决问题的方案。
发表于 2022-10-5 14:25:38 | 显示全部楼层
for /F 空值是不会被赋值到变量的,所以第二第三行当没有工作时间时,没有 tokens 3。token 2就是工作组。
用2楼的方法判断一下是可以的。
 楼主| 发表于 2022-10-5 14:41:30 | 显示全部楼层
回复 2# hlzj88


   感谢指点,为什么执行代码,没有输出?
发表于 2022-10-5 16:27:10 | 显示全部楼层
回复 4# xslxslxsl ent

我测试没有问题,复制的你的文本做为测试文本,系统win7
 楼主| 发表于 2022-10-5 16:50:05 | 显示全部楼层
回复 5# hlzj88


    好的,谢谢,我再看看,谢谢!
发表于 2022-10-6 09:41:07 | 显示全部楼层
如果文件只有3列的话:
  1. @echo off
  2. (for /f "tokens=1-3 delims=," %%i in (in_txt.txt) do (
  3.     if not "%%k"=="" (
  4.         echo,%%i,%%k
  5.     ) else (
  6.         echo,%%i,%%j
  7.     )
  8. ))>out_txt.txt
  9. pause&exit
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-19 17:03 , Processed in 0.018501 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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