Board logo

标题: 如何将多行数据变成一行? [打印本页]

作者: shelby     时间: 2009-1-22 14:30    标题: 如何将多行数据变成一行?

数据如下:

DESCRIPTION          SUM(ENTRY021)                                             
-------------------- -------------                                             
东莞东                       73700                                             
广州                        225071                                             
广州东                      122342                                             
深圳                        105813                                             
深圳西                       40930                                             

已选择5行。

希望得出如下的结果:
东莞东73700,广州东225071,深圳105813,深圳西40930。
作者: lihan584     时间: 2009-1-22 15:46
::ywj.txt是原文件,bcwj.txt是将要保存的文件
@echo off
FOR /F "tokens=1,2 delims= " %%a in (ywj.txt) do set /p jg=%%a%%b,<nul>>bcwj.txt
pause
作者: shelby     时间: 2009-1-22 16:45
非常感谢!我知道前2行可以通过 skip=3 来去掉。但是还有点小问题就是最后一行的数据(已选择5行。)如何去掉?
作者: yishanju     时间: 2009-1-22 17:46
用type xxx.txt |findstr /rc:"[0-9]*" 过滤一次
作者: tireless     时间: 2009-1-22 17:57

@echo off
for /f "skip=3 tokens=1,2" %%a in (a.txt) do (
  set /a "n+=1,1/(5-n)" 2>nul || echo %%a%%b。>>a_new.txt && exit /b
  set /p =%%a%%b,<nul>>a_new.txt
)

作者: shelby     时间: 2009-1-22 18:09
楼上的强!do里面的命令好多看不懂,能够解释一下?呵呵。。另外,这些都是在循环里面控制输出的,能否将结果放在一个变量中,然后在循环外引用?
作者: tireless     时间: 2009-1-22 18:55    标题: Re 6楼

set /a n+=1 变量 n 的数值加 1
set /a 1/(5-n) 为了判断行数。当除数为零时导致出错,然后就会执行 || 后的命令。 (参考: CMD/DOS下符号的作用参考)
2>nul “标准错误输出”输出到空设备 (参考: 重定向中的秘密)
set /p =%%a%%b,<nul>>a_new.txt 以空设备作为输入源,代替了从键盘输入,从而语句结束。因为没有输入回车符,所以不会换行。

------------------

将结果放到变量中:
@echo off
setlocal enabledelayedexpansion
for /f "skip=3 tokens=1,2" %%a in (a.txt) do (
  set /a n+=1
  if !n!==5 set "str=!str!%%a%%b。" & goto Next
  set "str=!str!%%a%%b,"
)

:Next
echo %str%
pause
[ Last edited by tireless on 2009-1-22 at 19:43 ]
作者: netbenton     时间: 2009-1-23 00:24    标题: 在2楼上增强就可以了

@echo off
FOR /F "tokens=1,2 delims= " %%a in (ywj.txt) do if "%%a"=="已选择5行。" exit&set /p jg=%%a%%b,<nul>>bcwj.txt
pause