Board logo

标题: [已结]文本 相同行数据分列输出 [打印本页]

作者: flybird2020     时间: 2009-5-21 05:42    标题: [已结]文本 相同行数据分列输出

A.txt内容如下:
a        A        aa        1        2        3        4        5        6        7        8        9        10        11        12        13        14        15        16
b        B        bb        1        2
c        C        cc        1
d        D        dd        1        2        3        4        5
期望输出结果到B.txt如下:
a        A        aa        1
a        A        aa        2
a        A        aa        3
a        A        aa        4
a        A        aa        5
a        A        aa        6
a        A        aa        7
a        A        aa        8
a        A        aa        9
a        A        aa        10
a        A        aa        11
a        A        aa        12
a        A        aa        13
a        A        aa        14
a        A        aa        15
a        A        aa        16
b        B        bb        1
b        B        bb        2
c        C        cc        1
d        D        dd        1
d        D        dd        2
d        D        dd        3
d        D        dd        4
d        D        dd        5
自己写了个笨代码,觉得十分丑陋。。。望达人指点
@echo off&&setlocal enabledelayedexpansion
for /f "tokens=1-20 delims=        " %%a in (A.txt) do (
>>A_1.txt echo %%a        %%b        %%c        %%d
>>A_1.txt echo %%a        %%b        %%c        %%e
>>A_1.txt echo %%a        %%b        %%c        %%f
>>A_1.txt echo %%a        %%b        %%c        %%g
>>A_1.txt echo %%a        %%b        %%c        %%h
>>A_1.txt echo %%a        %%b        %%c        %%i
>>A_1.txt echo %%a        %%b        %%c        %%j
>>A_1.txt echo %%a        %%b        %%c        %%k
>>A_1.txt echo %%a        %%b        %%c        %%l
>>A_1.txt echo %%a        %%b        %%c        %%m
>>A_1.txt echo %%a        %%b        %%c        %%n
>>A_1.txt echo %%a        %%b        %%c        %%o
>>A_1.txt echo %%a        %%b        %%c        %%p
>>A_1.txt echo %%a        %%b        %%c        %%q
>>A_1.txt echo %%a        %%b        %%c        %%r
>>A_1.txt echo %%a        %%b        %%c        %%s
>>A_1.txt echo %%a        %%b        %%c        %%t
        )
for /f "tokens=1-20 delims=        " %%a in (A_1.txt) do (
        if "%%d" neq "" >>B.txt echo %%a        %%b        %%c        %%d)
[ Last edited by flybird2020 on 2009-5-21 at 06:06 ]
作者: tireless     时间: 2009-5-21 05:59
如果每列的字符不含空格:
@echo off
(for /f "tokens=1-3,*" %%1 in (a.txt) do (
  for %%a in (%%4) do echo %%1 %%2 %%3 %%a
))>b.txt

作者: flybird2020     时间: 2009-5-21 06:06


  Quote:
Originally posted by tireless at 2009-5-21 05:59 AM:
如果每列的字符不含空格:
@echo off
(for /f "tokens=1-3,*" %%1 in (a.txt) do (
  for %%a in (%%4) do echo %%1 %%2 %%3 %%a
))>b.txt

惭愧,FOR的用法我还是知道的太少了
完美的代码
作者: 26933062     时间: 2009-6-2 16:31


@gawk "{for(i=4;i<=NF;i+=1)print $1,$2,$3,$i}" a.txt>b.txt