首页 > 解决方案 > 批量将每一行拆分为多行

问题描述

我的 txt 文件如下所示:

A1;A2;A3
B1;B2

我想像这样拆分它:

A1;;;A2
A2;;;A3
A3;;;A3
B1;;;B2
B2;;;B2

规则是:对于每一行,取两个相邻元素并用它们创建一个新的输出行,对于一行的最后一个元素:也创建一个新的输出行,但使用该元素两次。

这是我的尝试:

(
    for /f "tokens=1-4 delims=;" %%a in (%FilePath%) do (
        for /f "tokens=1-4 delims=;" %%x in (%FilePath%) do (
            echo %%a;;;%%y
        )
    )
)>%FilePath_Final%

但它给出了错误的格式:

A1;;;A2
A1;;;B2
B1;;;A2
B1;;;B2

如何使用批处理命令拆分行以获得预期的结果?

PS:A1、A2、B1等只是一些字符串示例,我可以有各种字符串

以下是文件内容的示例:

XB8998901;XB8998900;8051191;24048271;24048270
XB0134812;XB0134810;XB0134801;XB0134800
XB6312701;XB6312700
XB6314201;XB6314200

输出应如下所示:

XB8998901;;;XB8998900
XB8998900;;;8051191
8051191;;;24048271
24048271;;;24048270
24048270;;;24048270
XB0134812;;;XB0134810
XB0134810;;;XB0134801
XB0134801;;;XB0134800
XB0134800;;;XB0134800
XB6312701;;;XB6312700
XB6312700;;;XB6312700
XB6314201;;;XB6314200
XB6314200;;;XB6314200

标签: batch-filetextsplit

解决方案


@echo off
setlocal enabledelayedexpansion
set "last="
(for /f "delims=" %%a in (old.txt) do (
  for %%b in (%%a) do (
    if defined last echo !last!;;;%%b
    set "last=%%b"
  )
echo !last!;;;!last!
set "last="
))>new.txt
fc new.txt compare.txt

old.txt(您的示例文件):

XB8998901;XB8998900;8051191;24048271;24048270
XB0134812;XB0134810;XB0134801;XB0134800
XB6312701;XB6312700
XB6314201;XB6314200

compare.txt (您的示例所需的输出):

XB8998901;;;XB8998900
XB8998900;;;8051191
8051191;;;24048271
24048271;;;24048270
24048270;;;24048270
XB0134812;;;XB0134810
XB0134810;;;XB0134801
XB0134801;;;XB0134800
XB0134800;;;XB0134800
XB6312701;;;XB6312700
XB6312700;;;XB6312700
XB6314201;;;XB6314200
XB6314200;;;XB6314200

输出:

Vergleichen der Dateien new.txt und compare.txt
FC: Keine Unterschiede gefunden

(翻译:Comparing files new.txt and compare.txt; FC: no differences encountered


推荐阅读