Board logo

标题: 如何判断除外场合 [打印本页]

作者: q385131731     时间: 2009-3-1 09:29    标题: 如何判断除外场合

我想用批处理完成这个功能:
结束除系统进程以外的所有进程。

结束所有进程的批处理可以这样实现:
for /f "skip=3" %%a in ('tasklist') do taskkill /f /im %%a
但我想保留系统进程,意思就是除系统进程外的乱七八糟进程全部结束,那怎么去除外呢。
作者: q385131731     时间: 2009-3-1 09:34
如果这样太麻烦了。

for /f "skip=3" %%a in ('tasklist') do if %%a==3号进程名(do if %%a==2号进程名(do if %%a==1号进程名(taskkill /f /im %a)))

我想要多条件处理和条件的除外判断(可惜dos貌似不支持多分支)
请高手指教,谢谢。
作者: q385131731     时间: 2009-3-1 10:19
有人吗  谢谢了
作者: ZJHJ     时间: 2009-3-1 10:32
可以按列表(系统进程),以外的统统全部结束

@echo off
@echo 以下是指定保留进程,可以自己添加或删除...>1w.txt
@echo system>>1w.txt
@echo smss.exe>>1w.txt
@echo csrss.exe>>1w.txt
@echo safeboxtray.exe>>1w.txt
@echo 360tray.exe>>1w.txt
@echo winlogon.exe>>1w.txt
@echo services.exe>>1w.txt
@echo lsass.exe>>1w.txt
@echo svchost.exe>>1w.txt
@echo alg.exe>>1w.txt
@echo dllhost.exe>>1w.txt
@echo explorer.exe>>1w.txt
@echo ctfmon.exe>>1w.txt
@echo conime.exe>>1w.txt
@echo wmiprvse.exe>>1w.txt
@echo dllhost.exe>>1w.txt
@echo wuauclt.exe>>1w.txt
@echo notepad.exe>>1w.txt
@echo tasklist.exe>>1w.txt
@echo cmd.exe>>1w.txt
@echo shadowtip.exe>>1w.txt
@echo shadowservice.exe>>1w.txt
start 1w.txt
pause
::显示指定进程以外的进程
cd.>2w.txt
for /f %%i in (1w.txt) do set %%i=a
for /f %%i in ('tasklist /nh') do  if /i not defined %%i echo %%i>>2w.txt
::获取指定进程以外进程的pid号
tasklist /nh>1w.txt
cd.>3w.txt
for /f  %%i in (2w.txt) do findstr /i /r /c:"\<%%i\>" 1w.txt>>3w.txt
cd.>1w.txt
for /f "tokens=2 delims= " %%i in (3w.txt) do @echo %%i>>1w.txt
del 2w.txt
del 3w.txt
::按pid号自动终止进程
for /f  %%i in (1w.txt) do (
   ntsd -c q -p  "%%i"
)
del 1w.txt

[ Last edited by ZJHJ on 2009-3-3 at 08:34 ]
作者: q385131731     时间: 2009-3-1 11:06
万分感谢
作者: q385131731     时间: 2009-3-2 07:57
能请高手帮我解释下以下的运行原理,谢谢
cd.>2w.txt
for /f %%i in (1w.txt) do set %%i=a
for /f %%i in ('tasklist /nh') do  if /i not defined %%i echo %%i>>2w.txt

cd.>2w.txt的用处是?
set %%i=a 的用处是?
defined的用处是?
它们是如何得到除 1w.txt 的进程名的。
作者: q385131731     时间: 2009-3-2 08:00
for /f %%i in ('tasklist /nh') do  if /i not defined %%i echo %%i>>2w.txt
这句里面好像没有和1.txt有关的命令,那它是怎么获取1.txt里的内容的呢?
希望好心的高手能帮忙解答。
作者: Hanyeguxing     时间: 2009-3-2 11:17
看这一段:
for /f %%i in (1w.txt) do set %%i=a
作者: q385131731     时间: 2009-3-3 08:51
把a代入变量i
貌似代入其他也能实现
能否请高手解释下 for /f %%i in (1w.txt) do set %%i=a
本菜鸟是新人,实在难懂,磕头谢。
作者: tireless     时间: 2009-3-3 10:13
试试这个:
@echo off
set 保留进程=smss.exe csrss.exe winlogon.exe services.exe lsass.exe svchost.exe alg.exe explorer.exe conime.exe
setlocal enabledelayedexpansion
for /f "skip=3" %%a in ('tasklist /nh^|findstr /libv "%保留进程%"') do (
  set im=/im %%a !im!
)
taskkill /f %im%

作者: q385131731     时间: 2009-3-4 08:52
setlocal enabledelayedexpansion
这句看不懂
作者: tireless     时间: 2009-3-4 09:05


  Quote:
Originally posted by q385131731 at 2009-3-4 08:52 AM:
setlocal enabledelayedexpansion
这句看不懂

是启用变量延迟。论坛里搜索 setlocal enabledelayedexpansion,有很多相关帖子。
作者: q385131731     时间: 2009-3-7 07:55
谢谢