亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

基于python監控程序是否關閉

發布時間:2020-10-24 07:23:02 來源:腳本之家 閱讀:151 作者:墨水熊 欄目:開發技術

這篇文章主要介紹了基于python監控程序是否關閉,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

監控一個服務系exe在他關閉后打印,原想可以使用win32process.EnumProcesses()來獲取所有程序pid,再根據pid獲取的進程名進行對比,來判斷程序是否關閉,但遇到個問題,我無法根據pid獲取到進程名,除非使用psutil包,可這樣又讓自己的程序過于臃腫,我又想到去查找c++的例子希望可以得到一些幫助,然而c++的api函數在python中并不存在,我之前遇到這種問題基本都使用wmi去解決的。

 import wmi
   c = wmi.WMI()
   for process in c.Win32_Process():
     print process.ProcessId, process.Name

但wmi的速度可是出奇的慢,實在不適合,

最后我在外面找到個例子,可以很好的解決該問題

from win32com.client import GetObject
  _wmi = GetObject('winmgmts:')

  # collect all the running processes
  processes = _wmi.ExecQuery('Select * from win32_process')
  for p in processes:

      print((p.ProcessId, p.ExecutablePath, p.CommandLine, p.Name))

由此全部代碼為
def wmi_sql_all_name(pname):#全部程序列表
  from win32com.client import GetObject
  _wmi = GetObject('winmgmts:')
  processes = _wmi.ExecQuery('Select * from win32_process')
  for p in processes:
    if p.name==pname:
      return p.ProcessId
def process_restat(pname):
  import win32security, win32event#-----------------------------------------獲取令牌
  hToken = win32security.OpenProcessToken(win32api.GetCurrentProcess(),
                      win32con.TOKEN_ADJUST_PRIVILEGES | win32con.TOKEN_QUERY) # 打開自己的程序令牌
  luid = win32security.LookupPrivilegeValue(None, 'SeDebugPrivilege') # 查看自己的權限,并寫入權限關鍵字
  PyTOKEN = ((luid, win32con.SE_PRIVILEGE_ENABLED),) # 將這些做成序列用做參數
  pyt1 = win32security.AdjustTokenPrivileges(hToken, 0, PyTOKEN) # 權限寫入#----------------------------------------
  processid=wmi_sql_all_name(pname)
  if processid!= None:
    hprocess = win32api.OpenProcess(win32con.PROCESS_ALL_ACCESS, False, processid)
    win32event.WaitForSingleObject(hprocess, -1)
    win32api.CloseHandle(hprocess)
    print U'已關閉'
  else:
    print u'未啟動'

首先需要獲取令牌,否則獲取很多服務或者系統進程的信息都會報權限不足

使用OpenProcess得到程序句柄,

使用WaitForSingleObject得到程序的已通知狀態也就是運行狀態,第二參數為等待時間 -1 為永久等待

注意該函數會死鎖線程,但不會占用cpu,很適合丟在子線程里,比無限循環跑程序列表要有效率得多

-------------------

突然想到有sql語句了 我為啥還要循環呢?

def wmi_sql_all_name(pname):
  from win32com.client import GetObject

  _wmi = GetObject('winmgmts:')
  processes = _wmi.ExecQuery("Select * from win32_process where name= '%s'"%(pname))
  try:
    return processes[0].ProcessId
  except:
    print u"沒有發現程序"
    return None

將wmi_sql_all_name方法改為以以上

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

明溪县| 忻州市| 东光县| 铜川市| 股票| 澄江县| 石柱| 德令哈市| 桂平市| 灵山县| 松江区| 香河县| 泾阳县| 漳平市| 赤城县| 余干县| 沙雅县| 东乌珠穆沁旗| 夏河县| 山东省| 临潭县| 鄂托克前旗| 临夏县| 嵊泗县| 广州市| 汉源县| 贵阳市| 吉隆县| 垫江县| 铜川市| 兴山县| 华安县| 南靖县| 景德镇市| 南京市| 广灵县| 满洲里市| 建平县| 彭州市| 颍上县| 丰原市|