标题: 发现一个得到字符串长度的方法
[打印本页]
作者: everest79
时间: 2007-12-31 17:59
标题: 发现一个得到字符串长度的方法
命令如下:
(echo string&echo.)|findstr /o ".*"
批处理中应用:
set/p x=input:
for /f "skip=1 delims=:" %%i in ('^(echo "%x%"^&echo.^)^|findstr /o ".*"') do set/a l=%%i-5
echo %l%
pause
[
Last edited by everest79 on 2008-1-1 at 12:06 AM ]
作者: s11ss
时间: 2007-12-31 18:21
会产生临时文件:
echo string>t&for %a in (t) do set/a z=%~za-2&del t
作者: everest79
时间: 2007-12-31 18:49
嗯,方法有很多,主要是刚发现findstr的/o参数作用,记得原来有个专门总结这个的贴子,找不到了
作者: HAT
时间: 2007-12-31 21:17
学习
发现字符串以重定向符号结束时代码会出错
只要把%x%加上双引号就行了
作者: everest79
时间: 2007-12-31 21:27
已更正,嘿嘿,没多测试
作者: ZJHJ
时间: 2007-12-31 22:31
请问一下:
为什么?
楼 主 的测试方法比实际的要多 2 ???
第 2 楼 的测试方法比实际的要少 2 ???
参数 /a 有什么用????
作者: HAT
时间: 2007-12-31 22:38
The /A switch specifies that the string to the right of the equal sign
is a numerical expression that is evaluated. The expression evaluator
is pretty simple and supports the following operations, in decreasing
order of precedence:
作者: everest79
时间: 2008-1-1 00:08
这个字符偏移好像是包括换行与回车还有什么的,所以在ansi文本中每行多两个字节,在内存中多三具
set /a 是表示后边的为数字表达式,你可以理解为四则运算
作者: HAT
时间: 2008-1-1 12:16
我觉得多出来的那个3就是:行结束符、回车符、换行符。
不知道理解的对不对?
作者: erel
时间: 2008-1-3 06:29
新手学习中
作者: BatMan
时间: 2008-1-7 02:43
这个方法可以,但是我试了一下,发现这方法比逐个字符判断要慢很多...
SETLOCAL ENABLEDELAYEDEXPANSION
SET "TMPITEM=Hello World!"
:: FINDSTR /O法,添加了空判断以适应TMPITEM=空的情况
ECHO !TIME!
IF DEFINED TMPITEM (
FOR /F "skip=1 delims=:" %%I IN ('^(echo "%TMPITEM%"^&echo.^)^|findstr /o ".*"') DO (
SET /A "TMPITEM_LEN = %%I - 4"
)
) ELSE (
SET "TMPITEM_LEN=0"
)
ECHO !TIME!
ECHO %TMPITEM_LEN%
:: 逐个字符计数法
SET "TMPITEM_LEN=0"
ECHO !TIME!
IF DEFINED TMPITEM (
:GetLenLoop
SET "TMPTMP=!TMPITEM:~%TMPITEM_LEN%,1!" && SET /A "TMPITEM_LEN += 1" && GOTO :GetLenLoop
)
ECHO !TIME!
ECHO !TMPITEM_LEN!
ENDLOCAL
FINDSTR /o 法在我的机器上一般要80~100ms,而逐个字符计数法一般是<10ms~20ms左右。可能是因为FINDSTR毕竟是外部命令调用的缘故吧。
[
Last edited by BatMan on 2008-1-7 at 03:04 AM ]
作者: zh159
时间: 2008-1-7 10:17
Quote: |
Originally posted by BatMan at 2008-1-7 02:43:
这个方法可以,但是我试了一下,发现这方法比逐个字符判断要慢很多...
[code]
SETLOCAL ENABLEDELAYEDEXPANSION
SET "TMPITEM=Hello World!"
:: FINDSTR /O法 ... |
|
FINDSTR /O 好处是可以判断双字节字符,在单双字节字符窗口中排版很有用
作者: BatMan
时间: 2008-1-7 13:47
Quote: |
Originally posted by zh159 at 2008-1-7 10:17:
FINDSTR /O 好处是可以判断双字节字符,在单双字节字符窗口中排版很有用 |
|
原来如此...
我用"世界你好Hello World!"来测试,FINDSTR /O报的是字节数,而逐字符计算则得到字符数,明白楼上的意思了。
但是发现个新问题...如果测试字符串稍改为"世界你好!Hello World!",则Hello World前后的!号在变量延迟扩展时会被视作特殊符号而导致最终结果错误。用%号也会有类似的情况。这问题有解决方案吗?