VBS列出windows更新列表

Set objSession = CreateObject("Microsoft.Update.Session")
Set objSearcher = objSession.CreateUpdateSearcher

dim fso, f
set fso = CreateObject("Scripting.FileSystemObject")

path = fso.GetFolder(".").Path

'在脚本所在目录创建一个xls文件来记录,实际上是一个html表格内容,可以用excel打开
set f = fso.CreateTextFile(path + "\WindowsUpdatesList.xls", true, -1)
'第二个参数表示目标文件存在时是否覆盖
'object.CreateTextFile(filename[, overwrite[, unicode]])
'其中unicode参数可以为以下几种:

'-2 以系统默认格式打开文件。 
'-1 以 Unicode 格式打开文件。 
'0 以 ASCII 格式打开文件。
'未指定unicode参数时发现表头乱码【用的是utf-8编码】,但内容部份是正确的【用的是unicode】,不知为何?

intHistoryCount = objSearcher.GetTotalHistoryCount

Set colHistory = objSearcher.QueryHistory(1, intHistoryCount)

f.WriteLine "<table><thead><tr><th>更新时间</th><th>补丁标题</th><th>补丁说明</th><th>操作</th></tr></thead><tbody>"

For Each objEntry in colHistory
	f.WriteLine "<tr>"
	f.WriteLine "<td>" & objEntry.Date & "</td>"
	f.WriteLine "<td>" & objEntry.Title & "</td>"
	f.WriteLine "<td>" & objEntry.Description & "</td>"
	Select Case objEntry.Operation
        Case 1
            f.WriteLine "<td>安装</td>"
        Case 2
            f.WriteLine "<td>卸载</td>"
        Case Else
            f.WriteLine "<td>未知</td>"
    End Select
	f.WriteLine "</tr>"
Next

f.WriteLine "</tbody></table>"
set f = nothing
set fso = nothing


如果需要调试,可以在命令行输入:wscript /x script.vbs,然后选择调试器进行调试

附一张调试图片,可以看到objEntry还有更多属性:


posted @ 2016-08-12 16:46  网事  阅读(501)  评论(0编辑  收藏  举报