Board logo

标题: [文本处理] 求助:批处理把文本拼接成固定格式 [打印本页]

作者: mmdpe    时间: 2018-5-31 10:27     标题: 求助:批处理把文本拼接成固定格式

求助如下:
有三列数据几百行,要求把一个文本里的三列数据拼接成指定长度,并另存为unix格式文件,例如:

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


生成unix格式的数据:
A!!!!!BB@@@@@@CCC¥¥¥¥¥¥¥
D!!!!!EE@@@@@@FFF¥¥¥¥¥¥¥
...
...
作者: gfwlxx    时间: 2018-5-31 11:05

为什么一定要unix格式,随便写个工具很容易实现干吗一定要批处理
作者: mmdpe    时间: 2018-5-31 11:12

本帖最后由 mmdpe 于 2018-5-31 11:14 编辑

回复 2# gfwlxx


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

请大神协助!!!!收下小弟双膝!!!
作者: yhcfsr    时间: 2018-5-31 14:58

本帖最后由 yhcfsr 于 2018-5-31 15:02 编辑

BAT 别想了,powershell可以。
不过有个问题,列之间的分隔符是中文逗号还是英文逗号,在你的示例用的中文全角逗号。最好截取一段数据做为样本发上来。
在处理结果中,!号和¥都是全角,@是半角。符号搞错了,结果可想而知,因此希望你可以就符号做下强调。
作者: Batcher    时间: 2018-5-31 20:37

  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"
复制代码





欢迎光临 批处理之家 (http://www.bathome.net/) Powered by Discuz! 7.2