zoukankan      html  css  js  c++  java
  • 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还有更多属性:


  • 相关阅读:
    浅谈树的重心
    倍增的奇妙用处
    KMP——从入门到不会打题
    万能的进制哈希
    浅谈扫描线算法的应用
    无需Flash录视频——HTML5中级进阶
    一个模仿微信群聊的H5页面
    关于建议
    前端技术学习线路
    Kurento安装与入门02——运行示例前的准备
  • 原文地址:https://www.cnblogs.com/apollokk/p/6713805.html
Copyright © 2011-2022 走看看