[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

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

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

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

评分人数

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

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

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

评分人数

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

TOP

返回列表