Board logo

标题: [文本处理] 批处理如何快速转换以下格式文本? [打印本页]

作者: 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 编辑
  1. @echo off
  2. (for /f %%a in (a.txt) do (
  3.    setlocal enabledelayedexpansion
  4.    for %%b in (a b c) do set /p %%b=
  5.    if defined c echo !a:*:=!^|!b:*:=!^|!c:*:=!*
  6.    endlocal
  7. ))<a.txt>b.txt
复制代码

作者: gawk    时间: 2012-5-3 17:22

  1. 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
  1. sort /+65535 /rec 65335 b.txt /o c.txt
复制代码





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