标题: [已解决一半]数据换列?
[打印本页]
作者: oicq63236
时间: 2008-9-2 16:36
标题: [已解决一半]数据换列?
1|aaaa|bbbb|cccc|sddsd|
2|aaa|cccccccc|ddddd|3dfdsf|fdsfsdfsd|
.....
每行的列数不固定,现想把后两列调换位置,即
1|aaaa|bbbb|
sddsd|
cccc|
2|aaa|cccccccc|ddddd|
fdsfsdfsd|
3dfdsf|
[
Last edited by oicq63236 on 2008-9-9 at 10:38 PM ]
作者: huahua0919
时间: 2008-9-2 20:34
@echo off&setlocal enabledelayedexpansion
for /f "delims=" %%i in (e.txt) do (
set a=%%i
set a=!a:^|=.!
for /f %%a in ("!a!") do (
set Before=%%~na
set LastOne=%%~xa
for /f %%x in ("!Before!") do (
set BBefore=%%~nx
set LLastOne=%%~xx
)
)
for /f %%m in ("!BBefore!!LastOne!!LLastone!.") do (
set ChangeB=%%m
set ChangeB=!ChangeB:.=^|!
echo !ChangeB!
)
)
pause
作者: HAT
时间: 2008-9-2 21:53
标题: Re 2楼
如果两个|之间的字符存在.,会出问题吧。
作者: oicq63236
时间: 2008-9-2 22:27
实际情况是,那些字符串中会有金额出现,例如3000.53,再怎么修改一下呢?
作者: HAT
时间: 2008-9-2 23:05
如果按照2楼的思路,可以把|替换成一个你的文件中不会出现的字符。
但我觉得这样做始终存在风险。
作者: lxmxn
时间: 2008-9-2 23:31
这样的问题还是用 awk 比较好点
gawk "BEGIN{OFS=FS=\"^|\"} {t=$(NF-2);$(NF-2)=$(NF-1);$(NF-1)=t;print}" your_file
作者: huahua0919
时间: 2008-9-2 23:41
斑竹的第三方工具用的熟练.重新写了个,基本能实现上面的要求
@echo off&setlocal enabledelayedexpansion
for /f "delims=" %%i in (e.txt) do (
set m=
set n=
set l=
set a=%%i
set a=!a:^|= !
for %%a in (!a!) do (
set /a n+=1
set _!n!=%%a
)
set /a m=n-1
set /a l=m-1
for /l %%t in (1 1 !l!) do (set /p=!_%%t!^|<nul)
call set dim=%%_!n!%% %%_!m!%%
set dim=!dim: =^|!
echo !dim!^|
)
pause
作者: HAT
时间: 2008-9-3 00:15
学习斑竹的思路
作者: oicq63236
时间: 2008-9-4 09:27
谢谢大家了!
作者: oicq63236
时间: 2008-9-9 22:05
huahua0919
兄,你的代码不错,可惜有些地方领会不了,还请赐教!
@echo off&setlocal enabledelayedexpansion
for /f "delims=" %%i in (e.txt) do ( <--将E.TXT中的一行字串赋于%%i
set m=
set n=
set l=
set a=%%i
set a=!a:^|= ! <-将%%i中的|线替换为空格
for %%a in (!a!) do ( <-将%%i分解为各个字串
set /a n+=1 <-记录每个字串的位置
set _!n!=%%a ??????(_!n!是什么意思)
)
set /a m=n-1 <-定义倒数第二个字串位置
set /a l=m-1 <-定义不需转换的最后一个字串位置
for /l %%t in (1 1 !l!) do (
set /p=!_%%t!^|<nul) ??????
call set dim=%%_!n!%% %%_!m!%% <-交换最后两例位置,为什么必须得call呢,直接set却不行?
set dim=!dim: =^|! <-将空格换回|线
echo !dim!^| 这里不是只输出!dim!吗?
难道是接着上边set /p=..这儿继续输 出?
)
本人愚钝,请赐教,谢谢!(以上有注释的地方正确吗)
pause
[
Last edited by oicq63236 on 2008-9-9 at 10:37 PM ]
作者: HAT
时间: 2008-9-9 22:30
代码保存为test.bat
双击运行看看结果
setlocal enabledelayedexpansion
for /f "delims=" %%i in (e.txt) do (
set m=
set n=
set l=
set a=%%i
set a=!a:^|= !
for %%a in (!a!) do (
set /a n+=1
set _!n!=%%a
)
set /a m=n-1
set /a l=m-1
for /l %%t in (1 1 !l!) do (set /p=!_%%t!^|<nul)
call set dim=%%_!n!%% %%_!m!%%
set dim=!dim: =^|!
echo !dim!^|
)
pause
作者: oicq63236
时间: 2008-9-9 22:38
代码已运行过了,很好使,只是不懂意思,想弄明白!
作者: HAT
时间: 2008-9-9 22:42
这样会不会清楚些?
setlocal enabledelayedexpansion
for /f "delims=" %%i in (e.txt) do (
set m=
set n=
set l=
set a=%%i
set a=!a:^|= !
for %%a in (!a!) do (
set /a n+=1
set _!n!=%%a
echo _!n!
pause
)
set /a m=n-1
set /a l=m-1
for /l %%t in (1 1 !l!) do (set /p=!_%%t!^|<nul)
call set dim=%%_!n!%% %%_!m!%%
set dim=!dim: =^|!
echo !dim!^|
)
pause