Solved

How to return a list of software installed on a computer?

Posted on 2004-08-16
5
301 Views
Last Modified: 2010-05-18
I am just wondering is there anyway to return a list of software which installed on a computer. I am currently using WMI (Windows Management Information) classes to retrieve such information as drive, processor and operating system information. Your help would be gratefully appreciated.
0
Comment
Question by:edmundg
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
5 Comments
 
LVL 48

Expert Comment

by:Mikal613
ID: 11809545
Well you can loop through c:\program files and see the current applications
0
 
LVL 86

Expert Comment

by:Mike Tomlinson
ID: 11809918
It is impossible to list ALL software on a system.

You could certainly determine what programs are listed in the Add/Remove section of the conrol panel but that is not always accurate as sometimes applications get orphaned there even though they were uninstalled long ago.

Additionally, not all programs on a system are listed there.  Any app that doesn't require installation will simply reside on the hard drive somewhere, and not necessarily in the "Program Files" folder either.

With that info in mind...you can duplicate the Add/Remove list by going to this key in the registry:

    HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Uninstall

Then simply enumerate all the entries and fetch the DisplayName value from each one.

Regards,

Idle_Mind
0
 
LVL 7

Accepted Solution

by:
natloz earned 125 total points
ID: 11810601
Here is something I played with...the PRODUCT (search 7) gives you a list of software installed with MSI Installer:

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
        Dim search1 As New ManagementObjectSearcher("SELECT * FROM Win32_ComputerSystem")
        Dim search2 As New ManagementObjectSearcher("SELECT * FROM Win32_CDROMDrive")
        Dim search3 As New ManagementObjectSearcher("SELECT * FROM Win32_PointingDevice")
        Dim search4 As New ManagementObjectSearcher("SELECT * FROM Win32_Processor")
        Dim search5 As New ManagementObjectSearcher("SELECT * FROM Win32_SystemEnclosure")
        Dim search6 As New ManagementObjectSearcher("SELECT * FROM Win32_OperatingSystem")
        Dim search7 As New ManagementObjectSearcher("SELECT * FROM Win32_Product")

        Dim moInfo As ManagementObject

        For Each moInfo In search1.Get()
            txtInfo.Text = ("Computer: " & moInfo("Name").ToString() & ControlChars.CrLf & _
            "User Name: " & moInfo("UserName").ToString() & ControlChars.CrLf & _
            "Domain: " & moInfo("Domain").ToString() & ControlChars.CrLf & _
            "Total RAM: " & moInfo("TotalPhysicalMemory").ToString() & ControlChars.CrLf & _
            "Processor Count: " & moInfo("NumberOfProcessors").ToString() & ControlChars.CrLf)
        Next moInfo

        For Each moInfo In search2.Get()
            txtInfo.Text = txtInfo.Text + ("CDRom: " & moInfo("Name").ToString() & ControlChars.CrLf)
        Next moInfo

        For Each moInfo In search3.Get()
            txtInfo.Text = txtInfo.Text + ("Mouse: " & moInfo("Name").ToString() & ControlChars.CrLf)
        Next moInfo

        For Each moInfo In search4.Get()
            txtInfo.Text = txtInfo.Text & _
            ("Processor Description: " & moInfo("Description").ToString() & ControlChars.CrLf & _
            "Processor Name: " & moInfo("Name").ToString() & ControlChars.CrLf & _
            "Max Clock Speed: " & moInfo("MaxClockSpeed").ToString() & ControlChars.CrLf)
        Next moInfo

        For Each moInfo In search5.Get()
            txtInfo.Text = txtInfo.Text & _
            ("Manufacturer: " & moInfo("Manufacturer").ToString() & ControlChars.CrLf & _
            "Serial Number: " & moInfo("SerialNumber").ToString() & ControlChars.CrLf)
        Next moInfo

        For Each moInfo In search6.Get()
            txtInfo.Text = txtInfo.Text & _
            ("Operating System: " & moInfo("Name").ToString() & ControlChars.CrLf)
        Next moInfo

        txtInfo.Text = txtInfo.Text + "--------------------" & ControlChars.CrLf

        For Each moInfo In search7.Get()
            txtInfo.Text = txtInfo.Text & ("Product Name: " & moInfo("Name").ToString() & ControlChars.CrLf)
        Next moInfo


    End Sub
0
 
LVL 86

Expert Comment

by:Mike Tomlinson
ID: 11810640
Here is an example of enumerating the Uninstall key and placing the list into a ListBox:

Imports Microsoft.Win32

Public Class Form1
    Inherits System.Windows.Forms.Form

#Region " Windows Form Designer generated code "

    Public Sub New()
        MyBase.New()

        'This call is required by the Windows Form Designer.
        InitializeComponent()

        'Add any initialization after the InitializeComponent() call

    End Sub

    'Form overrides dispose to clean up the component list.
    Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)
        If disposing Then
            If Not (components Is Nothing) Then
                components.Dispose()
            End If
        End If
        MyBase.Dispose(disposing)
    End Sub

    'Required by the Windows Form Designer
    Private components As System.ComponentModel.IContainer

    'NOTE: The following procedure is required by the Windows Form Designer
    'It can be modified using the Windows Form Designer.  
    'Do not modify it using the code editor.
    Friend WithEvents ListBox1 As System.Windows.Forms.ListBox
    <System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent()
        Me.ListBox1 = New System.Windows.Forms.ListBox
        Me.SuspendLayout()
        '
        'ListBox1
        '
        Me.ListBox1.Anchor = CType((((System.Windows.Forms.AnchorStyles.Top Or System.Windows.Forms.AnchorStyles.Bottom) _
                    Or System.Windows.Forms.AnchorStyles.Left) _
                    Or System.Windows.Forms.AnchorStyles.Right), System.Windows.Forms.AnchorStyles)
        Me.ListBox1.Location = New System.Drawing.Point(8, 8)
        Me.ListBox1.Name = "ListBox1"
        Me.ListBox1.Size = New System.Drawing.Size(432, 277)
        Me.ListBox1.TabIndex = 0
        '
        'Form1
        '
        Me.AutoScaleBaseSize = New System.Drawing.Size(5, 13)
        Me.ClientSize = New System.Drawing.Size(448, 294)
        Me.Controls.Add(Me.ListBox1)
        Me.Name = "Form1"
        Me.Text = "Add/Remove Program Listing"
        Me.ResumeLayout(False)

    End Sub

#End Region

    Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        Try
            Dim rk As RegistryKey = Registry.LocalMachine.OpenSubKey("Software\Microsoft\Windows\CurrentVersion\Uninstall")
            Dim sk As String
            Dim appKey As RegistryKey
            Dim displayNameValue As Object
            Dim displayName As String
            ListBox1.Sorted = True
            If Not (rk Is Nothing) Then
                For Each sk In rk.GetSubKeyNames
                    appKey = rk.OpenSubKey(sk)
                    displayNameValue = appKey.GetValue("DisplayName")
                    If Not (displayNameValue Is Nothing) Then
                        ListBox1.Items.Add(CType(displayNameValue, String))
                    End If
                Next
            End If
        Catch ex As Exception
            MsgBox(ex.Message, MsgBoxStyle.Information, "Error Accessing Registry")
        End Try
    End Sub
End Class
0

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This article explains how to create and use a custom WaterMark textbox class.  The custom WaterMark textbox class allows you to set the WaterMark Background Color and WaterMark text at design time.   IMAGE OF WATERMARKS STEPS Create VB …
Calculating holidays and working days is a function that is often needed yet it is not one found within the Framework. This article presents one approach to building a working-day calculator for use in .NET.
There's a multitude of different network monitoring solutions out there, and you're probably wondering what makes NetCrunch so special. It's completely agentless, but does let you create an agent, if you desire. It offers powerful scalability …
If you’ve ever visited a web page and noticed a cool font that you really liked the look of, but couldn’t figure out which font it was so that you could use it for your own work, then this video is for you! In this Micro Tutorial, you'll learn yo…

628 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question