国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > VBScript > 正文

用vbs實現的瞬間關閉多個系統進程的腳本

2020-07-26 11:56:43
字體:
來源:轉載
供稿:網友
程序試驗環境為 windows xp_sp2,主要針對系統存在多個需要中斷進程的情況下,瞬間成批中斷進程。
復制代碼 代碼如下:

'---------------------------------------------------------------------------------- 
On Error Resume next 
Set fs=CreateObject("scripting.filesystemobject") 
Set os=CreateObject("wscript.shell") 
Set os0=createobject("shell.application") 
Set d0=CreateObject("scripting.dictionary") 
Set wmi=GetObject("winmgmts://.") 
Set pro_s=wmi.instancesof("win32_process") 

'-------------創建臨時文本文件文件,把當前進程輸入該文本文件之中并通過記事本打開之 
'---------同時把進程對應序號 和 pid 傳遞給dictionary(d0)一份 
filename=fs.GetTempName 
set f1=fs.CreateTextFile(filename,True) 
msg="序號"&vbTab&"名稱"&vbTab&"PID"&vbTab&"程序文件"&vbtab&now&Chr(10) 
f1.Writeline(msg) 
n=1 
For Each p In pro_s 
f1.WriteLine(n&". "&p.name&"    ,    "&p.handle&"    ,    "&p.commandline&Chr(10)) 
d0.Add ""&n,Trim(p.handle) 
n=n+1 
Next 
f1.Close 
os0.MinimizeAll 
os.Exec "notepad.exe "&filename 
wscript.sleep 500 

'--------------等待用戶輸入欲中斷的進程相關的序號列,確定之后關閉并刪除臨時文本文件 
x=InputBox("請根據"&filename&"中的內容"+Chr(10)+ _ 
     "選擇需要同時中斷的進程對應序號:"+Chr(10)+ _ 
     "(序號之間用','間隔 例如:'1,3,5,7,11')","選擇") 
os.AppActivate filename&" - 記事本" 
os.SendKeys "%fx" 
WScript.Sleep 500 
fs.DeleteFile filename 

'--------如果用戶取消了操作,就退出程序 
If x="" then wscript.quit 
'--------把用戶輸入的序號列中相關的序號傳遞給一個數組 xs 
xs=Split(x,",",-1,1) 
'-----------對用戶輸入的序號列進行校對,將重復序號標記為 -2,計算實際序號個數 
For i=0 to ubound(xs) '---利用雙重循環將重復輸入的內容保留一份,其他的標記為-1 
for n=0 to ubound(xs) 
    if n=i then  
     n=n+1 
     if n>ubound(xs) then exit for 
    end if 
    if Trim(xs(n))=Trim(xs(i)) Or _ 
     Trim(xs(n))="" Then  
     xs(n)="-1" 
    end If 
next 
Next 

w=0 '----把不真實可用的序號剔除并計算出其個數 
For i=0 To UBound(xs) 
If d0.Exists(xs(i))=False Then  
     xs(i)="-2" 
     w=w+1 
End If 
Next 

w=(UBound(xs)+1-w)    '---得出可用的序號個數 
'------------如果序列中沒有輸入任何序號就退出程序 
If w=0 Then 
MsgBox "需要中斷的進程列表為空!" 
WScript.Quit 
End If 

'-------------根據用戶輸入信息中斷相應進程 
m=0 
For i=0 To UBound(xs) 
If xs(i) <> "-2" then '---只有真實可用的序號才參與循環 
For Each p In pro_s 
    If Trim(p.handle)=trim(d0(xs(i))) Then '---如果進程pid號碼正是需要中斷的就嘗試中斷 
     p_name=p.name 
     pd=p.terminate() 
     If pd=0 Then '---判斷中斷進程的嘗試是否成功 
      msg=p_name&" 進程中斷成功!" 
      m=m+1 
     Else 
      msg=p_name&" 進程中斷失敗!" 
     End If 
     os.popup msg,1,"通知",64+0 
    End If 
Next 
end if 
Next 

os.popup    w&"個目標進程,已經中斷了"&m&"個" ,5,"通知",64+0 
WScript.quit 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 温州市| 合山市| 连城县| 龙里县| 手游| 萨迦县| 都匀市| 惠水县| 兰西县| 崇仁县| 梁河县| 吉木乃县| 九江县| 临武县| 长武县| 灵山县| 吉安市| 阳城县| 特克斯县| 尉氏县| 青浦区| 新巴尔虎右旗| 皮山县| 固阳县| 潮安县| 轮台县| 边坝县| 佛教| 清水河县| 巧家县| 若尔盖县| 教育| 团风县| 镇巴县| 邓州市| 鄂伦春自治旗| 清水河县| 若尔盖县| 宁安市| 民权县| 九龙坡区|