标题: 请教一个文本排列问题
[打印本页]
作者: haiyuey
时间: 2009-4-20 23:51
标题: 请教一个文本排列问题
文本为:
王一,2
王一,5
张二,4
张二,5
张二,8
刘三,2
求输出结果为:
王一,2 5
张二,4 5 8
刘三,2
[
Last edited by haiyuey on 2009-4-21 at 00:11 ]
作者: haiyuey
时间: 2009-4-21 03:21
没人知道吗?
作者: hongewuyan
时间: 2009-4-21 03:53
@echo off
setlocal ENABLEDELAYEDEXPANSION
if exist b.txt del b.txt
set m=""
for /f "tokens=1,2 delims=," %%i in (a.txt) do (
if /i not "%%i"=="!m!" (
>>b.txt echo %%i,%%j
set m=%%i
) else (
sed -i "s/^%%i.*/& %%j/" b.txt
sed -i "s/$/\r/" b.txt
set m=%%i
)
)
以上代码我测试是可以的,不过需要你系统里面有sed这个命令,论坛上很好找到的,4.07版本以上应该可以.
作者: tireless
时间: 2009-4-21 04:23
@echo off&setlocal enabledelayedexpansion
set "file=a.txt"
set /p var=<"%file%"
set "var2=%var:*,=%" & set var=!var:,%var:*,=%=!
(for /f "usebackq skip=1 tokens=1,2 delims=," %%a in ("%file%") do (
if "%%a" neq "!var!" (
echo !var!,!var2!
set "var=%%a" & set var2=%%b
) else set var2=!var2! %%b
)
echo !var!,!var2!)>result.txt
start result.txt
作者: haiyuey
时间: 2009-4-21 04:29
三楼这个好像不行,数据换一个排列再执行就没用了!
[
Last edited by haiyuey on 2009-4-21 at 04:35 ]
作者: haiyuey
时间: 2009-4-21 04:34
三楼的不行,四楼的应该可以,先谢过,再试下
作者: sady2009
时间: 2009-4-21 07:19
名字是连着排列的吗? 还是打乱的?
作者: netbenton
时间: 2009-4-21 07:27
不管是打乱,还是连着的都可以
@echo off&setlocal enabledelayedexpansion
for /f "tokens=1,2 delims=, " %%a in (%~n0.txt) do (set "#%%a=!#%%a!%%b ")
for /f "tokens=1,2 delims==#" %%a in ('set #') do (echo %%a,%%b)
pause
[
Last edited by netbenton on 2009-4-21 at 05:29 ]
作者: freeants001
时间: 2009-4-21 07:29
set "var2=%var:*,=%"中竟然可以使用通配符,感谢tireless的代码,学了一招,呵呵~~
作者: sady2009
时间: 2009-4-21 08:09
终于看懂了8楼老大的代码
set #用的很妙,能把#开头的变量都列出来,再用for 处理。
不知道 cmd最大可以支持多少个变量. 有数量限制吗?
作者: tireless
时间: 2009-4-21 08:12
标题: Re 10楼
http://technet.microsoft.com/en-us/library/bb490954.aspx Quote: |
The maximum individual environment variable size is 8192bytes.
The maximum total environment variable size for all variables, which includes variable names and the equal sign, is 65,536KB. |
|
[
Last edited by tireless on 2009-4-21 at 08:14 ]
作者: THENEWLIFE
时间: 2009-4-21 22:16
看了很长时间还是不怎么动下面这2句,还大大门帮忙解释下
set /p var=<"%file%"
这里的VAR=< 里面的这个“<”是转义符的意思吗
意思是把FILE的值附给 VAR吧,然后用SET /P做为输入吗
set "var2=%var:*,=%" & set var=!var:,%var:*,=%=!
"var2=%var:*,=%" 里面的“*和,”的意思是把所有字符和逗号转换成空吗
var=!var:,%var:*,=%=!这句是一个变量替换的嵌套吧
意思是把%var:*,=%替换的值再和, 替换成空吗。看了很多这方便的资料
在实际应用上就不知道怎么下手,不知道我理解的对吗,还请大大门指点,最好举个实例解释下,谢谢了~
作者: jmz573515
时间: 2009-4-21 22:43
set fso=createobject("scripting.filesystemobject")
set file=fso.opentextfile("1.txt")
do while file.atendofstream<>true
n=file.readline:s=split(n,","):a=s(0):b=s(1)
if instr(sn,a)=0 then
n=vbcrlf &n:sn=a:sm=sm & n
else
sm=sm & " " &b
end if
loop
file.close
wsh.echo mid(sm,3)
作者: freeants001
时间: 2009-4-22 00:17
fso=WScript.createobject("scripting.filesystemobject");
sss=fso.opentextfile("a.txt").readall();
re=/((?:\n|^)([^,]+),[^\r\n]+)\r\n((?:.*\r\n)*?)(?:\2,([^\r\n]+\r\n))/
while(re.test(sss))sss=sss.replace(re,"$1 $4$3");
fso.createtextfile("a_dest.txt",1,0).write(sss)
作者: tireless
时间: 2009-4-22 00:40
标题: Re 12楼
< 是重定向符号。
set /p var= 默认是从控制台(键盘)接受输入源,这句等同于
set /p var=<con。把
con 换成
文件,就是把文件作为输入源了。而变量只允许一行字符,所以只有文件的第一行设为了 var 的值。
%var:*,=% 是把第一个
, 及前面所有字符替换为空。
只有这一种通配符用法,其他的如
%var:,*=%、
%var:?,=% 都无效。
!var:,%var:*,=%=!
假设
var=王一,2
%var:*,=% 取得的值是
2,然后
!var:,2=! 取得的值是
王一。
[
Last edited by tireless on 2009-4-22 at 09:13 ]
作者: THENEWLIFE
时间: 2009-4-22 02:34
RIRELESS
谢谢,大大讲的很详细,已经明白了