[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

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

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

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


生成unix格式的数据:
A!!!!!BB@@@@@@CCC¥¥¥¥¥¥¥
D!!!!!EE@@@@@@FFF¥¥¥¥¥¥¥
...
...

为什么一定要unix格式,随便写个工具很容易实现干吗一定要批处理

TOP

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

回复 2# gfwlxx


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

请大神协助!!!!收下小弟双膝!!!

TOP

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

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

TOP

  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"
复制代码
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

返回列表