标题: [文本处理] 求助:批处理把文本拼接成固定格式 [打印本页]
作者: 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
- @echo off
- (for /f "skip=1 tokens=1-3 delims=," %%a in ('type "a.txt"') do (
- echo %%a!!!!!%%b@@@@@@%%c¥¥¥¥¥¥¥
- ))>"a_tmp.txt"
- REM PowerShell 5+ 支持 NoNewline
- 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 |