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

[文本处理] [已解决]如何根据文本文件第5列的值取第一列的值并输出到文本文件

[复制链接]
发表于 2019-1-13 06:31:19 | 显示全部楼层 |阅读模式
本帖最后由 vioer 于 2019-1-14 06:32 编辑

有这样一个文本文件,共有7列,每列用逗号隔开:
10,仓库15,0,0,0,-1,-1
19,仓库D,0,0,0,-1,-1
22,仓库12,0,0,0,-1,-1
21,仓库K,656908,788128,1,38640,40184
36,仓库Q,0,0,0,-1,-1
1,仓库235,0,0,0,-1,-1
15,仓库9,20385324,7275702,1,43696,39724
7,仓库G,0,0,0,-1,-1


如果某行的第五列值为1,则取出该行的第一列数据,用逗号分隔合并后输出到文本,比如上面的数据,最终输出到文本中是这个样子:
21,15

熬了一晚,卡到这里,搞不定了。。。
发表于 2019-1-13 07:48:21 | 显示全部楼层
Powershell :
  1. gc 0.txt|%{if($_ -match '^(.*)(,\w+){3},1,'){$n+=($matches[1])}};$($n -join ',')>ref.log
复制代码
bat

  1. @echo off
  2. for /f "tokens=1,5 delims=," %%a in (0.txt) do if %%b==1 call set "n=%%a,%%n%%"
  3. (call echo %%n:~0,-1%%)>ref.log
复制代码

评分

参与人数 2技术 +2 收起 理由
yhcfsr + 1 学习了,数组的一种用法
vioer + 1 谢谢,问题解决!

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-18 22:47 , Processed in 0.016763 second(s), 7 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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