找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 28691|回复: 5

[文本处理] 【已解决】BAT:一列数据如何按规律重组

[复制链接]
发表于 2014-3-29 13:25:45 | 显示全部楼层 |阅读模式
本帖最后由 思想之翼 于 2014-3-29 15:30 编辑

txt文本有一列0-9之间的数据,共12600行,欲按下列规律将该列数据重组:
第1行&第2行     第3行&第4行   第5行&第6行 ...    第29行&第30行
第31行&第32行  第33行&第34行 第35行&第36行 ... 第59行&第60行
第61行&第62行  第63行&第64行 第65行&第66行 ... 第89行&第90行
...                                                                   ... 第59行&第12600行  
重组后的数据为文本格式(可以显示00 01),共15列420行,列与列之间的空格为Tab

评分

参与人数 1PB +2 收起 理由
Batcher + 2 感谢给帖子标题标注[已解决]字样

查看全部评分

发表于 2014-3-29 14:01:53 | 显示全部楼层
本帖最后由 apang 于 2014-3-29 22:03 编辑
  1. @echo off & setlocal enabledelayedexpansion
  2. for /f "delims=g" %%a in ('cmd /u /c echo,有') do set "Tab=%%a"
  3. (for /f "delims=" %%a in (1.txt) do (
  4.     set "strOld=!strNew!" & set "strNew=%%a"
  5.     set /a n+=1,m=n%%2,k=n%%30
  6.     if "!m!"=="0" set /p=!strOld!^&!strNew!%Tab%<nul
  7.     if "!k!"=="0" echo,
  8. ))>2.txt
  9. pause
复制代码
整复杂了,改一下,呵呵

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢帮助

查看全部评分

 楼主| 发表于 2014-3-29 14:32:17 | 显示全部楼层
本帖最后由 思想之翼 于 2014-3-29 15:29 编辑

回复 2# apang

感谢您的帮助!解决问题。
发表于 2014-3-29 14:41:36 | 显示全部楼层
貌似未定义strOld时,n需要为1才对吧。否则第一次m=0时,好像已取值到第3行了

评分

参与人数 1技术 +1 收起 理由
apang + 1 确实

查看全部评分

发表于 2014-3-29 14:57:13 | 显示全部楼层
回复 4# xxpinqz


    确实,感谢提醒
发表于 2014-3-30 00:30:32 | 显示全部楼层
修改下2楼  效率稍提高点
  1. @echo off&setlocal enabledelayedexpansion
  2. for /f "delims=g" %%a in ('cmd /u /c echo,有') do set "Tab=%%a"
  3. (for /f %%i in (1.txt) do (
  4.     if defined str (
  5.        set "var=!var!%Tab%!str!&%%i"
  6.        set "str="
  7.     )  else set "str=%%i"
  8.        set /a n+=1,m=n%%30
  9.        if "!m!" == "0" echo!var!&set "var="
  10. )
  11. if defined var echo!var!
  12. )>2.txt
  13. pause
复制代码

评分

参与人数 1技术 +1 收起 理由
apang + 1 Very Good

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-21 03:06 , Processed in 0.033138 second(s), 18 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表