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

[文本处理] 批处理如何快速转换以下格式文本?

求批量快速转换以下格式文本:

时间:2011-12-7 9:42:38
公司代码:1001
公司名称:中央电视台

要快速转换成以下这种格式:
2011-12-7 9:42:38|1001|中央电视台*

总共只有3行?
有很多行,每隔3行合并成1行?

TOP

我没说清楚,补充如下 :
时间: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|香港*
.....

中间是“|”最后是“*”
一行一组数据

TOP

本帖最后由 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
复制代码
1

评分人数

TOP

  1. gawk -F: "{if(NR%3)printf \"%s^|\",$2; else print $2\"*\"}" a.txt >b.txt
复制代码

TOP

运行了以上二条代码,啥也没得到

TOP

回复 4# CrLf

搞定了,谢谢

TOP

回复 4# CrLf

高人,还有一事求助,转换过来的这个文件我想倒序排列,就是最后一行的变成第一行,倒数第二行的变成第二行....................依此类推到最后第一行变成最后一行

TOP

回复 8# sunflowerr_88
  1. sort /+65535 /rec 65335 b.txt /o c.txt
复制代码

TOP

返回列表