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

[文本处理] 求助:批处理把文本拼接成固定格式

[复制链接]
发表于 2018-5-31 10:27:07 | 显示全部楼层 |阅读模式
求助如下:
有三列数据几百行,要求把一个文本里的三列数据拼接成指定长度,并另存为unix格式文件,例如:

原始文本里的数据:
数据A,数据B,数据C
A,BB,CCC
D,EE,FFF
...
...


生成unix格式的数据:
A!!!!!BB@@@@@@CCC¥¥¥¥¥¥¥
D!!!!!EE@@@@@@FFF¥¥¥¥¥¥¥
...
...
发表于 2018-5-31 11:05:22 | 显示全部楼层
为什么一定要unix格式,随便写个工具很容易实现干吗一定要批处理
 楼主| 发表于 2018-5-31 11:12:48 | 显示全部楼层
本帖最后由 mmdpe 于 2018-5-31 11:14 编辑

回复 2# gfwlxx


    应用场景:
公司其他部门会定期给我们提供300多条数据,我需要把他生成unix格式的文件传给另外一个同事。数据之间还需要添加一些固定长度的的字符。之前我都是用EXCEL宏来做的。
如果能实现bat双击执行,把他发给我的文件直接生成我要的,就太幸福了

请大神协助!!!!收下小弟双膝!!!
发表于 2018-5-31 14:58:56 | 显示全部楼层
本帖最后由 yhcfsr 于 2018-5-31 15:02 编辑

BAT 别想了,powershell可以。
不过有个问题,列之间的分隔符是中文逗号还是英文逗号,在你的示例用的中文全角逗号。最好截取一段数据做为样本发上来。
在处理结果中,!号和¥都是全角,@是半角。符号搞错了,结果可想而知,因此希望你可以就符号做下强调。
发表于 2018-5-31 20:37:52 | 显示全部楼层
  1. @echo off
  2. (for /f "skip=1 tokens=1-3 delims=," %%a in ('type "a.txt"') do (
  3.     echo %%a!!!!!%%b@@@@@@%%c¥¥¥¥¥¥¥
  4. ))>"a_tmp.txt"
  5. REM PowerShell 5+ 支持 NoNewline
  6. powershell -c "((Get-Content a_tmp.txt) -join """`n""") + """`n""" | Set-Content -NoNewline a_unix.txt"
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-18 10:36 , Processed in 0.019352 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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