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

首頁 > 編程 > VBScript > 正文

用vbs實(shí)現(xiàn)的瞬間關(guān)閉多個(gè)系統(tǒng)進(jìn)程的腳本

2020-06-26 18:15:09
字體:
供稿:網(wǎng)友
程序利用 vbs 的wmi 、scripting.filesystemobject、shell.application、scripting.dictionary、wscript.shell的相關(guān)功能功能實(shí)現(xiàn)將當(dāng)前進(jìn)程列表顯示在一個(gè)文本文件中,通過用戶界面的選擇,確定需要瞬間中斷的進(jìn)程列表,然后中斷之。
 
程序試驗(yàn)環(huán)境為 windows xp_sp2,主要針對系統(tǒng)存在多個(gè)需要中斷進(jìn)程的情況下,瞬間成批中斷進(jìn)程。 
復(fù)制代碼代碼如下:

'----------------------------------------------------------------------------------  
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")  

'-------------創(chuàng)建臨時(shí)文本文件文件,把當(dāng)前進(jìn)程輸入該文本文件之中并通過記事本打開之  
'---------同時(shí)把進(jìn)程對應(yīng)序號 和 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  

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

'--------如果用戶取消了操作,就退出程序  
If x="" then wscript.quit  
'--------把用戶輸入的序號列中相關(guān)的序號傳遞給一個(gè)數(shù)組 xs  
xs=Split(x,",",-1,1)  
'-----------對用戶輸入的序號列進(jìn)行校對,將重復(fù)序號標(biāo)記為 -2,計(jì)算實(shí)際序號個(gè)數(shù)  
For i=0 to ubound(xs) '---利用雙重循環(huán)將重復(fù)輸入的內(nèi)容保留一份,其他的標(biāo)記為-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 '----把不真實(shí)可用的序號剔除并計(jì)算出其個(gè)數(shù)  
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)    '---得出可用的序號個(gè)數(shù)  
'------------如果序列中沒有輸入任何序號就退出程序  
If w=0 Then  
MsgBox "需要中斷的進(jìn)程列表為空!"  
WScript.Quit  
End If  

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

os.popup    w&"個(gè)目標(biāo)進(jìn)程,已經(jīng)中斷了"&m&"個(gè)" ,5,"通知",64+0  
WScript.quit  

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 积石山| 伊宁县| 渝北区| 虞城县| 临潭县| 玉门市| 开远市| 民乐县| 黎川县| 石城县| 蒙自县| 韶关市| 南宫市| 新营市| 平顶山市| 嵊泗县| 青海省| 遵义县| 巩义市| 三河市| 白银市| 茶陵县| 格尔木市| 卫辉市| 巴塘县| 中超| 朔州市| 淮安市| 连云港市| 运城市| 正蓝旗| 怀宁县| 鲜城| 台南县| 昌图县| 永定县| 新宁县| 黄大仙区| 体育| 丹阳市| 宁武县|