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

[文本处理] 【已解决】BAT:多列多行数值,如何按特定方式转置

[复制链接]
发表于 2023-9-9 12:32:35 | 显示全部楼层 |阅读模式
本帖最后由 思想之翼 于 2023-9-9 16:56 编辑

【问题1】
D:\DATA\1.txt记录格式如下:
000        12345678
001        124
789        3
欲将多列多行数值,转置成1行,结果为:
000        12345678        001        124        789        3

【问题2】
D:\DATA\2.txt记录格式如下:
000        12345678        001        124        789        3
556        9        001        2589        666        541
欲将多列多行数值,每隔2列,转置成2列多行,结果为:
000        12345678
556        9
001        124
001        2589
789        3
666        541
或者逐行逐次每隔2列,转置成2列多行,结果为:
000        12345678
001        124
789        3
556        9
001        2589
666        541

评分

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

查看全部评分

发表于 2023-9-9 12:46:05 | 显示全部楼层
本帖最后由 wanghan519 于 2023-9-9 14:21 编辑

xargs
xargs -n2

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢分享 盼望详细指点

查看全部评分

发表于 2023-9-9 13:08:58 | 显示全部楼层
本帖最后由 77七 于 2023-9-9 13:10 编辑

code1
  1. @echo off
  2. (for /f "useback delims=" %%a in ("1.txt") do (
  3.         for %%b in (%%a) do (
  4.                 set /p=%%b <nul
  5.         )
  6. )
  7. echo=
  8. )>3.txt
复制代码


code2
  1. @echo off
  2. (for /f "useback delims=" %%a in ("2.txt") do (
  3.         call :1 "%%a"
  4. ))>4.txt
  5. pause & exit

  6.         :1
  7.         set str=%~1
  8.         :loop
  9.         for /f "tokens=1-2*" %%b in ("%str%") do (
  10.                 echo %%b %%c
  11.                 if "%%d" neq "" (
  12.                         set str=%%d
  13.                         goto :loop
  14.                 ) else exit /b
  15.         )
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢分享 结果正确

查看全部评分

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

本版积分规则

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

GMT+8, 2026-3-18 12:01 , Processed in 0.019260 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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