有一个很好的示例可以在Powerbuilder中使用 WMI 来终止正在运行的进程。
可以使用相同的技术获取 BaseBoard 的 SerialNumber 。我需要扩展相同的代码来处理WQL查询的返回值。
我要执行的WQL查询是:
SELECT Product, SerialNumber FROM Win32_BaseBoard
我可以执行上面的查询,但是在调用 ExecuteStatement ()函数之后,不知道如何将 SerialNumber 保存在变量中。
请查看链接以获取完整的PowerBuilder代码。 How to terminate a process if it has specific folder name in its path?
以下是从上面的链接中摘录的示例代码的一部分,以显示该功能。
wsh = CREATE OleObject
wsh.ConnectToNewObject("MSScriptControl.ScriptControl")
wsh.Language = "VBScript"
wsh.AddCode(TheCode)
TRY
wsh.ExecuteStatement(FunctionName)
CATCH (RunTimeError Re01)
MessageBox("Query Error", "Following code has some problems.~r~n~r~n" + TheCode, StopSign!)
END TRY
wsh.DisconnectObject()
DESTROY wsh
重要的函数调用 wsh.ExecuteStatement(FunctionName)
该函数调用后如何使用返回的 BaseBoard的序列号设置我的PowerBuilder局部变量?
答案 0 :(得分:-1)
OLEObject ole_wsh
Any la_baseboard[]
string ls_message
ole_wsh = CREATE OLEObject
ole_wsh.ConnectToNewObject("MSScriptControl.ScriptControl")
ole_wsh.Language = "vbscript"
ole_wsh.AddCode('Function rtnBaseBoard()~r~n' &
+ 'DIM objBaseBoard(2)~r~n' &
+ 'strComputer = "."~r~n' &
+ 'Set objWMIService =' &
+ ' GetObject("winmgmts:\\" & strComputer & "\root\cimv2")~r~n' &
+ 'Set colItems =' &
+ ' objWMIService.ExecQuery("SELECT Product, SerialNumber FROM Win32_BaseBoard")~r~n' &
+ 'For Each objItem in colItems~r~n' &
+ 'objBaseBoard(0) = objItem.Product~r~n' &
+ 'objBaseBoard(1) = objItem.SerialNumber~r~n' &
+ 'Next~r~n' &
+ 'rtnBaseBoard = objBaseBoard~r~n' &
+ 'End Function')
la_baseboard[] = ole_wsh.Eval("rtnBaseBoard")
ole_wsh.DisconnectObject()
DESTROY ole_wsh
ls_message = "Product: " + string(la_baseboard[1]) + "~r~n" + &
+ "SerialNumber: " + string(la_baseboard[2]) + "~r~n"
MessageBox("Win32 BaseBoard",ls_message)
查看更多示例