wmi 类“win32reg_addremoveprograms"的 64 位等效类? [英] 64bit equivalent class for a wmi class "win32reg_addremoveprograms"?

查看:37
本文介绍了wmi 类“win32reg_addremoveprograms"的 64 位等效类?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我下面的代码在 32 位 Windows 机器上完美运行,但是由于代码中使用了 32 位 WMI 类 win32reg_addremoveprograms,它拒绝在 64 位机器上运行.这个类有 64 位的等价物吗?

My code below works perfectly on a 32-bit Windows machine, however it refuses to work on a 64-bit machine due to the 32-bit WMI class win32reg_addremoveprograms used in the code. Is there a 64-bit equivalent of this class?

$ServerFile = "D:\SharePoint\Powershell\AddRemovePrograms\Machines.txt"
$ServerList = Get-Content $ServerFile

$Excel = New-Object -Com Excel.Application
$Excel.displayalerts=$False
$Excel.visible = $True

$workbook = $Excel.Workbooks.Add()
$workbook.workSheets.item(2).delete()
$workbook.WorkSheets.item(2).delete()

$Sheet = $workbook.WorkSheets.Item(1)
$Sheet.Name= "Program List";

$intRow = 1

foreach ($NextServer in $ServerList)
{
    $Sheet.Cells.Item($intRow,1) = "Computer Name"
    $Sheet.Cells.Item($intRow,2) = $NextServer

    $Sheet.Cells.Item($intRow,1).Interior.ColorIndex = 8
    $Sheet.Cells.Item($intRow,1).Font.ColorIndex = 11
    $Sheet.Cells.Item($intRow,1).Font.Bold = $True
    $Sheet.Cells.Item($intRow,2).Interior.ColorIndex = 8
    $Sheet.Cells.Item($intRow,2).Font.ColorIndex = 11
    $Sheet.Cells.Item($intRow,2).Font.Bold = $True

    $intRow = $intRow + 2
    $Sheet.Cells.Item($intRow,1) = "Programs"
    $Sheet.Cells.Item($intRow,1).Interior.ColorIndex = 12
    $Sheet.Cells.Item($intRow,1).Font.ColorIndex = 8
    $Sheet.Cells.Item($intRow,1).Font.Bold = $True
    $intRow = $intRow + 1

    $colItems =get-wmiobject -class "win32reg_addremoveprograms" -computername $NextServer  |  select-object -property DisplayName | sort-object  DisplayName

    foreach ($objItem in $colItems)
    {
        if ($objItem.DisplayName.IndexOf('Update') -eq -1 -and $objItem.DisplayName.IndexOf('2007 Microsoft Office') -eq -1)
        {   
            $Sheet.Cells.Item($intRow,1) = $objItem.DisplayName
            $intRow = $intRow + 1
        }
    }
    $intRow = $intRow + 2
}

$workArea = $Sheet.UsedRange
$workArea.EntireColumn.AutoFit()
$workbook.SaveAs("D:\SharePoint\Powershell\AddRemovePrograms\Programs.xls")
$workbook.close() 
$a = [System.Runtime.InteropServices.Marshal]::ReleaseComObject($workArea)
$a = [System.Runtime.InteropServices.Marshal]::ReleaseComObject($Sheet)
$a = [System.Runtime.InteropServices.Marshal]::ReleaseComObject($workbook)
$Excel.Quit()
$a = [System.Runtime.InteropServices.Marshal]::ReleaseComObject($Excel)
[System.GC]::Collect()
[System.GC]::WaitForPendingFinalizers() 
Remove-Variable Excel, intRow ,workbook, Sheet,colItems, ServerFile, ServerList, a

推荐答案

你有 SCCM/SMS 客户端安装在您的 64 位机器上?因为 Win32Reg_AddRemovePrograms WMI 类是由 SCCM/SMS 客户端添加的,因此如果您没有安装它,则不可用.

Do you have the SCCM/SMS client installed on your 64-bit machine? Because the Win32Reg_AddRemovePrograms WMI class is added by the SCCM/SMS client, and therefore isn't available if you don't have it installed.

另请注意,Win32Reg_AddRemovePrograms 仅提供有关 32 位已安装应用程序的信息.要获取有关 64 位应用程序的信息,请使用 Win32Reg_AddRemovePrograms64 类(在 SMS 2003 SP3 和更高版本中可用).

Note also that Win32Reg_AddRemovePrograms provide info on 32-bit installed applications only. To get info on 64-bit applications, use the Win32Reg_AddRemovePrograms64 class (available in SMS 2003 SP3 and later).

这篇关于wmi 类“win32reg_addremoveprograms"的 64 位等效类?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆