标题: [文本处理] 批处理如何快速转换以下格式文本? [打印本页]
作者: sunflowerr_88 时间: 2012-5-3 11:50 标题: 批处理如何快速转换以下格式文本?
求批量快速转换以下格式文本:
时间:2011-12-7 9:42:38
公司代码:1001
公司名称:中央电视台
要快速转换成以下这种格式:
2011-12-7 9:42:38|1001|中央电视台*
作者: gawk 时间: 2012-5-3 15:44
总共只有3行?
有很多行,每隔3行合并成1行?
作者: sunflowerr_88 时间: 2012-5-3 16:45
我没说清楚,补充如下 :
时间:2011-12-7 9:42:38
公司代码:1001
公司名称:中央电视台
时间:2011-12-7 10:42:38
公司代码:1002
公司名称:美国
时间:2011-12-7 11:42:38
公司代码:1003
公司名称:香港
......
有很多,都是这种格式,希望快速转换成
2011-12-7 9:42:38|1001|中央电视台*
2011-12-7 10:42:38|1002|美国*
2011-12-7 11:42:38|1003|香港*
.....
中间是“|”最后是“*”
一行一组数据
作者: CrLf 时间: 2012-5-3 17:15
本帖最后由 CrLf 于 2012-5-3 19:02 编辑
- @echo off
- (for /f %%a in (a.txt) do (
- setlocal enabledelayedexpansion
- for %%b in (a b c) do set /p %%b=
- if defined c echo !a:*:=!^|!b:*:=!^|!c:*:=!*
- endlocal
- ))<a.txt>b.txt
复制代码
作者: gawk 时间: 2012-5-3 17:22
- gawk -F: "{if(NR%3)printf \"%s^|\",$2; else print $2\"*\"}" a.txt >b.txt
复制代码
作者: sunflowerr_88 时间: 2012-5-3 18:38
运行了以上二条代码,啥也没得到
作者: sunflowerr_88 时间: 2012-5-3 19:20
回复 4# CrLf
搞定了,谢谢
作者: sunflowerr_88 时间: 2012-5-3 20:26
回复 4# CrLf
高人,还有一事求助,转换过来的这个文件我想倒序排列,就是最后一行的变成第一行,倒数第二行的变成第二行....................依此类推到最后第一行变成最后一行
作者: CrLf 时间: 2012-5-3 21:05
回复 8# sunflowerr_88 - sort /+65535 /rec 65335 b.txt /o c.txt
复制代码
欢迎光临 批处理之家 (http://www.bathome.net/) |
Powered by Discuz! 7.2 |