中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » [讨论]利用for命令获取文本中的文件路径和名字.
作者:
标题: [讨论]利用for命令获取文本中的文件路径和名字. 上一主题 | 下一主题
qingzangbasin
初级用户





积分 36
发帖 14
注册 2006-12-16
状态 离线
『楼 主』:  [讨论]利用for命令获取文本中的文件路径和名字.

首先感谢zh159,namejm,ccwan的指点.

     最近一直想写一个autorun.inf病毒的通杀程序.有些问题不好解决,放到这里请大家多多出出主意.

     autorun.inf的内容一般为以下几种形式:
1,
[autorun]
open=test.exe
icon=test.bmp
Shell\n=auto
shell\n\command=test.exe

2,
[autorun]
open=test.exe e
icon=test.bmp
Shell\n=auto
shell\n\command=test.exe e

3,
[autorun]
open=test.exe -r
icon=test.bmp
Shell\n=auto
shell\n\command=test.exe -r
4,
[autorun]
open=x:\test.exe
icon=test.bmp
Shell\n=auto
shell\n\command=x:\test.exe
5,
[autorun]
open=x:\test.exe e
icon=test.bmp
Shell\n=auto
shell\n\command=x:\test.exe e

我写的截取命令如下:
for /f "skip=1 tokens=2 delims== " %%i in (%driver%:\autorun.inf) do (
    echo %%i >>temp.txt)delims的等号后面有空格.
不知道大家还有更好的办法么?谢谢关注!
另外,xp和2003的批处理对for命令的支持情况一样么?为什么我在2003测试正常的脚本,拿到XP上就出错误,还删除其他文件?

    在for do()中,括号中的多条命令是否必须用 &&连接?我看到zh159大侠都是换行!

2006-12-21 01:30
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
namejm
荣誉版主

batch fan


积分 5226
发帖 1737
注册 2006-3-10
来自 成都
状态 离线
『第 2 楼』:  

  请问你想对 autorun.inf 文件做什么样的操作?



尺有所短,寸有所长,学好CMD没商量。
考虑问题复杂化,解决问题简洁化。
2006-12-21 01:40
查看资料  发短消息 网志   编辑帖子  回复  引用回复
qingzangbasin
初级用户





积分 36
发帖 14
注册 2006-12-16
状态 离线
『第 3 楼』:  



  Quote:
Originally posted by namejm at 2006-12-20 12:40 PM:
  请问你想对 autorun.inf 文件做什么样的操作?


for %%i in (c d e f g h i j k l m n o p q r s t u v w s y z) do (
    set Driver=%%i
  if exist %%i:\autorun.inf call :Check
)
:check
for /f "skip=1 tokens=2 delims== " %%i in (%driver%:\autorun.inf) do (
   taskkill /im /f %%i &&del /f /q /a -r -h -s -a %%i &&del /f /q /a -r -h -s -a %driver%:\%%i &&del %driver%:\autorun.inf


2006-12-21 02:15
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
qingzangbasin
初级用户





积分 36
发帖 14
注册 2006-12-16
状态 离线
『第 4 楼』:  



  Quote:
Originally posted by namejm at 2006-12-20 12:40 PM:
  请问你想对 autorun.inf 文件做什么样的操作?

这个代码是zh159大侠写的代码
for %%i in (c d e f g h i j k l m n o p q r s t u v w s y z) do (
    set Driver=%%i
  if exist %%i:\autorun.inf call :Check
)
echo 恭喜,没有发现病毒或者病毒被清理,程序3秒后自动退出。
ping -n 4 127.1 >nul
exit

:Check
set "vir=sxs.exe RavMonE.exe autorun.bat command.com c:\sxs.exe c:\RavMonE.exe c:\autorun.bat c:\command.com"
for %%n in (%vir%) do (
  for /f "tokens=1* delims==" %%i in (%Driver%:\autorun.inf) do if "%%j"=="%%n" call :%%~nn
)
goto :eof

:sxs
......
goto :eof


2006-12-21 02:17
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
namejm
荣誉版主

batch fan


积分 5226
发帖 1737
注册 2006-3-10
来自 成都
状态 离线
『第 5 楼』:  

  因为有些代码并不是你想要的结果,而有些代码本身就有错误,用代码是无法准确表达你的意图的,请用文字描述。



尺有所短,寸有所长,学好CMD没商量。
考虑问题复杂化,解决问题简洁化。
2006-12-21 02:23
查看资料  发短消息 网志   编辑帖子  回复  引用回复
qingzangbasin
初级用户





积分 36
发帖 14
注册 2006-12-16
状态 离线
『第 6 楼』:  



  Quote:
Originally posted by namejm at 2006-12-20 01:23 PM:
  因为有些代码并不是你想要的结果,而有些代码本身就有错误,用代码是无法准确表达你的意图的,请用文字描述。

用FOR 命令截取文件中的执行程序路径,比如得到sxs.exe,则跳转到处理sxs病毒的代码部分.
      在sxs代码部分,用for 命令截取执行程序路径,删除.比如得到c:\sxs.exe,则删除sxs.exe

      因为autorun.inf病毒在每个磁盘根目录下都有文件,而且有很多变种,所以我想根据其中的open=sxs.exe,来确定病毒类型,并处理。

2006-12-21 03:08
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: