Board logo

标题: 用SET命令逐个取字符串的问题。(已解决) [打印本页]

作者: zts59     时间: 2006-8-23 19:36    标题: 用SET命令逐个取字符串的问题。(已解决)

set char=
set /p char=     enter:
:test
set n=0
set "char0=!char:~%n%,1!"
if %char0%="" goto end
set /A n="n+1"
echo %char0%
goto test
:end
pause


想达到用户输入一串字符,然后把该字符串逐个分开,赋于变量后,再显示出来。
为什么这条指令有问题:
set "char0=!choice:~%n%,1!"

想知道这条指令的问题在什么地方。

水平有限,勿须优化代码(不考滤)。

[ Last edited by zts59 on 2006-8-24 at 13:00 ]
作者: namejm     时间: 2006-8-23 23:51
  假设你其他地方的语句都是正确的,只是你在前面设置了n=0,而后面的语句又没有对n的值作改动,所以,set "char0=!choice:~%n%,1!"一句中的%n%始终为0,你只能取到第一个字符。

  其实,你这段代码中set "char0=!choice:~%n%,1!"(choice是char的笔误吧?)是有问题的,没看出使用!!有何作用;整段代码执行会发生错误。

[ Last edited by namejm on 2006-8-23 at 23:55 ]
作者: 3742668     时间: 2006-8-24 08:11


  Quote:
Originally posted by zts59 at 2006-8-23 19:36:
set char=
set /p char=     enter:
:test
set n=0
set "char0=!char:~%n%,1!"
if %char0%="" goto end
set /A n="n+1"
echo %char0%
goto test
:end
pause


想达 ...

1.逻辑上的错误:

  Quote:
set n=0

在后面的goto test后,它会重新把n的值设置为0,就算你其他代码全部正确,也只会陷入一个死循环中,不停地显示第一个字符。
正解:
把它放到test标签前面去。

2.语法上的错误:

  Quote:
if %char0%="" goto end

正解:
if "char0%" == "" goto end
3.命令上的错误:
没有使用启用延迟环境变量的命令:setlocal ENABLEDELAYEDEXPANSION,导致后面的!!所包含的变量不被识别,而被当作是字符串。
正解:
在前面加上setlocal ENABLEDELAYEDEXPANSION
把你的代码略做修改如下:
@echo off
setlocal ENABLEDELAYEDEXPANSION
    set n=0
    set char=
    set /p char=     enter:

:test
    set "char0=!char:~%n%,1!"
    if "%char0%" == "" goto end
    set /A n="n+1"
    echo %char0%
goto test

:end
    pause
用来处理不包含敏感字符的字符串,基本上足够了。
作者: zts59     时间: 2006-8-24 08:59
谢谢,你们,有一处确实是笔误,
还有一处也是有逻辑上的问题,谢谢纠正

哦,还有一个if "char0%" == "" goto end

什么时候该引号,什么时候不用引号呢?

还有使用启用延迟环境变量的命令,再次感谢。