Board logo

标题: [其他] 【已解决】求助批处理ping命令返回值中的重定向符的特殊处理? [打印本页]

作者: qq362220083    时间: 2009-3-18 01:28     标题: 【已解决】求助批处理ping命令返回值中的重定向符的特殊处理?

最近做一个小脚本,对于ping命令返回结果输出到文件。

例子:
set ipadd=127.1
:s
for /f "skip=3 tokens=1,* delims= " %%a in ('ping.exe %ipadd% -n 1') do (
if /i "%%a"=="Reply" (
  call :msg "%%a %%b"
)
)
ping.exe 127.1 -n 6 >nul
goto :s
:msg
echo %~1>>log.txt

问题:
若ping 返回的像 Reply from 127.0.0.1: bytes=32 time<1ms TTL=555
里面含有重定向符,该如何输出到文件?

[ 本帖最后由 qq362220083 于 2009-3-18 12:30 编辑 ]
作者: qq362220083    时间: 2009-3-18 01:31

补充一下,不使用双引号的输出。

在变量两边加上双引号,或者使用 %1 不去除双引号,则可以输出,但输出后,两边带双引号,对于后期日志的处理不太方便
作者: lhjoanna    时间: 2009-3-18 02:19

  1. @echo off
  2. set ipadd=127.1
  3. for /f "skip=3 tokens=1*" %%a in ('ping %ipadd% -n 1') do (
  4.     if /i "%%a"=="Reply" (
  5.        echo %%a %%b>log.txt&goto end
  6.     )   
  7. )
  8. :end
  9. pause>nul
  10. goto :eof
复制代码

作者: qq362220083    时间: 2009-3-18 02:32

首先感谢版主的帮助,测试后确实输出了正确的结果。

但若使用call 传参呢?因为在工具中,需要专门call 日志输出,其中有个就是ping的返回结果,用双引号引起来的,在 日志输出 中使用%~1取消引号打算输出日志,总是失败
作者: lhjoanna    时间: 2009-3-18 02:45

那就这样:
  1. setlocal enabledelayedexpansion
  2. set ipadd=127.1
  3. :s
  4. for /f "skip=3 tokens=1*" %%a in ('ping %ipadd% -n 1') do (
  5.    if /i "%%a"=="Reply" (
  6.      call :msg "%%a %%b"
  7.    )
  8. )
  9. pause
  10. goto :eof
  11. :msg
  12. set "str=%~1"
  13. set "str=!str:<=^<!"
  14. echo %str%>log.txt
  15. goto :eof
复制代码
几点注意:
1.delims默认是空格和逗号分隔符,所以这里可以忽略
2.tokens=1,*,可以写为tokens=1*
3.若只取ping结果的那一行,只需要循环一次就跳出。
4.用call调用子程序,需要用goto :eof来返回。

[ 本帖最后由 lhjoanna 于 2009-3-18 02:47 编辑 ]
作者: qq362220083    时间: 2009-3-18 03:14

原帖由 lhjoanna 于 2009-3-18 02:45 发表
那就这样:setlocal enabledelayedexpansion
set ipadd=127.1
:s
for /f "skip=3 tokens=1*" %%a in ('ping %ipadd% -n 1') do (
   if /i "%%a"=="Reply" (
     call :msg "%%a %%b"
   )
)
pause
goto : ...


在输出的第二个set 能讲解下吗,看得太吃力,也不明白什么意思
作者: lhjoanna    时间: 2009-3-18 03:20

你是指这一句吧:set "str=!str:<=^<!"
使用了set的变量替换的功能,具体就是把变量中的<替换为^<。在特殊符号<前加^,这样echo到文件中时就只会把<看成一个普通的符号了。set的具体用法教学区有很多资料,可以到那里再详细学习下!
作者: qq362220083    时间: 2009-3-18 06:34

当初没仔细研究过替换功能,看来以后学习还要认真仔细才行
作者: zqz0012005    时间: 2009-3-18 08:41     标题: 回复 5楼 的帖子

开启了变量延迟就不需要set "str=!str:<=^<!"这一步了,直接
echo !str!>log.txt
作者: lhjoanna    时间: 2009-3-18 12:06

恩,是的啊,谢谢zqz提醒。刚又搜到了一个帖子,主要就是阐述变量延迟与特殊字符的关系。确实要好好思考下。http://www.cn-dos.net/forum/view ... E8%BF%9F&page=1




欢迎光临 批处理之家 (http://bbs.bathome.net/) Powered by Discuz! 7.2