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

[文本处理] 批处理如何获取文本每一行中第几列/指定列的内容

[复制链接]
发表于 2018-3-16 10:38:25 | 显示全部楼层 |阅读模式
本帖最后由 pcl_test 于 2018-3-16 14:53 编辑

求助,bat取文本中的第n个数值进行显示
要取文本中第54个字段显示,可是bat,超过了31就直接不取数了,有啥办法能取到第54的数吗?下面的例子中我想把tokens写成1-64,然后echo 54:%%54

希望大神解救

for /f " tokens=1-31 delims=," %%1 in (%GET_FILE%) do (
echo ----------------------

        echo 1:%%1



echo ----------------------
发表于 2018-3-16 12:39:36 | 显示全部楼层
一种办法是分段获取,像这样:
  1. @echo off
  2. for /f "tokens=31* delims=," %%i in (1.txt) do (
  3.     for /f "tokens=23 delims=," %%k in ("%%j") do echo;%%k
  4. )
  5. pause
复制代码
其中 31+23 = 54

另一种办法是计数,像这样:
  1. @echo off
  2. for /f "delims=" %%i in (1.txt) do (
  3.     set n=0
  4.     for %%j in (%%i) do (
  5.         set /a n+=1, "1/(n-54)" || echo;%%j
  6.     )
  7. )
  8. pause
复制代码
发表于 2018-3-16 14:27:38 | 显示全部楼层
利用两个临时文件可做到。
  1. copy /y "%GET_FILE%" "temp1.txt" >nul

  2. :lp
  3. set/a n+=1
  4. if %n%==54 (
  5. for /f "delims=        " %%a in (temp1.txt) do echo %n%:%%a
  6. del /f /q temp*.txt&pause&goto:eof
  7. )
  8. (type temp1.txt)>temp.txt&&(for /f "tokens=1,* delims=        " %%a in (temp.txt) do echo %%b)>temp1.txt
  9. goto :lp
复制代码
 楼主| 发表于 2018-3-16 15:02:45 | 显示全部楼层
回复 2# WHY


    感谢,用第一个实现了我的目的,能详细说下是怎么实现的吗?为什么先到了31,然后能往后寻找数据呢?
发表于 2018-3-16 19:30:50 | 显示全部楼层
回复 4# terryno


    批处理 for /f 中的 tokens 最大可取的数值为 31,for /f 最多能分割的列数为 32
第一个 for 把第 31 列赋值给 %%i,第 31 列之后的字符串(当成第 32 列)赋值给 %%j
第二个 for 把第 32 列再次分割,第 23 列赋值给 %%k
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-18 04:53 , Processed in 0.017301 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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