返回列表 发帖

[问题求助] 【已解决】VBS调用WMI时SELECT,WHERE,如果有两个条件怎么办?

本帖最后由 Tianorder 于 2015-7-6 17:53 编辑

比方说
Set colProcessList=objWMIService.ExecQuery ("select * from Win32_Process where Name='calc.exe' ")COPY
这行,是要关闭计算器程序,
如果,在同时也要关闭记事本程序怎么办?
我试了一下,不支持“or”也不支持“|”或者“||”
搜索,也搜索不到SELECT...WHERE,一般都是SELECT CASE
1

评分人数

    • Batcher: 感谢给帖子标题标注[已解决]字样PB + 2
您好

本帖最后由 pcl_test 于 2015-7-6 14:58 编辑

or可以的
Set objWMIService = GetObject("winmgmts:")
Set ProcessList = objWMIService.ExecQuery("select * from win32_process where name='calc.exe' or name='notepad.exe'")
If ProcessList.Count = 0 Then
  MsgBox "指定进程未运行或用户权限不足以获得其信息。"
Else
  For Each objProcess In ProcessList
      rtn = MsgBox("进程 " & objProcess.name & " 的 PID 是 " &  objProcess.ProcessId&vbCrLf&"您确定要终止该进程吗?", vbYesNo, "关闭进程")
      If rtn = 6 Then objProcess.Terminate
  Next
End IfCOPY
1

评分人数

    • Tianorder: 原来or后面要加name=,我还以为是直接加双引 ...技术 + 1

TOP

返回列表