[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

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

提取指定列,遇到空值,不能正确提取,比如,我要提取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

工作组不应有空白啊???

  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. )
复制代码
这个现象我也奇怪,道理不明白,所以本回答仅作为解决问题的方案。
目的,学习批处理

TOP

for /F 空值是不会被赋值到变量的,所以第二第三行当没有工作时间时,没有 tokens 3。token 2就是工作组。
用2楼的方法判断一下是可以的。

TOP

回复 2# hlzj88


   感谢指点,为什么执行代码,没有输出?

TOP

回复 4# xslxslxsl ent

我测试没有问题,复制的你的文本做为测试文本,系统win7
目的,学习批处理

TOP

回复 5# hlzj88


    好的,谢谢,我再看看,谢谢!

TOP

如果文件只有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
复制代码

TOP

返回列表