[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[其他] 【已解决】求助批处理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 编辑 ]
1

评分人数

    • Batcher: 感谢主动给标题标注[已解决]字样PB + 2

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

在变量两边加上双引号,或者使用 %1 不去除双引号,则可以输出,但输出后,两边带双引号,对于后期日志的处理不太方便

TOP

  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
复制代码

TOP

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

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

TOP

那就这样:
  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 编辑 ]

TOP

原帖由 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 能讲解下吗,看得太吃力,也不明白什么意思

TOP

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

TOP

当初没仔细研究过替换功能,看来以后学习还要认真仔细才行

TOP

回复 5楼 的帖子

开启了变量延迟就不需要set "str=!str:<=^<!"这一步了,直接
echo !str!>log.txt
命令行参考:hh.exe ntcmds.chm::/ntcmds.htm
求助者请拿出诚心,别人才愿意奉献热心!
把查看手册形成条件反射!

TOP

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

TOP

返回列表