标题: 用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.逻辑上的错误:
在后面的goto test后,它会重新把n的值设置为0,就算你其他代码全部正确,也只会陷入一个死循环中,不停地显示第一个字符。
正解:
把它放到test标签前面去。
2.语法上的错误:
正解:
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
什么时候该引号,什么时候不用引号呢?
还有使用启用延迟环境变量的命令,再次感谢。