Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

Use a vbscript to change a registry key based on information in an array

Posted on 2008-06-13
5
Medium Priority
?
1,358 Views
Last Modified: 2012-06-21
My company uses a config.xml file to determine where packages will be installed from. The location of the config file that each system should use is set through a registry key. Recently, we discovered that a lot of the systems did not have the correct registry key and need to be corrected.

Here is an example of my problem.
A system will look in HKLM\Software\Custom\Config and see \\USAT001\Custom\ccpconfig.xml as the location for the config file. However, this is incorrect and should be  \\USME032\Custom\ccpconfig.xml. Each system at my company uses the first four letter as the location in the computer name. So any system starting with USME should use  the \\USME032\Custom\ccpconfig.xml.

How can I script it so a the computer name is examined? Once the computer name is determined, it changes the registry key to the correct location based on the first four letter.

Any help would be appreciate greatly.
0
Comment
Question by:Lorrec
[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
  • 3
  • 2
5 Comments
 
LVL 38

Expert Comment

by:Shift-3
ID: 21781520
Paste the script below into a text file with a .vbs extension.  Running it will modify the string value Config under the key HKLM\Software\Custom.


Const HKEY_LOCAL_MACHINE = &H80000002
 
Set WSHShell = CreateObject("WScript.Shell")
strComputer = WshShell.ExpandEnvironmentStrings("%computername%")
strPrefix = Left(strComputer, 4)
 
Set objRegistry = GetObject _
    ("winmgmts:\\" & strComputer & "\root\default:StdRegProv")
 
strKeyPath = "Software\Custom"
strValueName = "Config"
strData = "\\" & strPrefix & "032\Custom\ccpconfig.xml"
 
errReturn = objRegistry.SetStringValue _
    (HKEY_LOCAL_MACHINE, strKeyPath, strValueName, strData)

Open in new window

0
 

Author Comment

by:Lorrec
ID: 21781831
Thank you for the quick response. This gets me started.

I have one more question if you do not mind.
Not all of the registry keys should be set to USME032\Custom\ccpconfig.xml. Would it be possible to have the different changes in the script so it can loop through them them and choose which is correct based on computer name.

For example,

First 4 of Computer Name                             Location of Config file
SCAB                                                      \\SCAB001\custom\config.xml
USMD                                                       \\USMD005\custom\config.xml

Would it be possible to have it look at the computer name and then decide based on the first 4 of that computer name what to change the registry to?
0
 
LVL 38

Accepted Solution

by:
Shift-3 earned 2000 total points
ID: 21782322
Ok, I think I see what you're saying.  

The revised code below allows you to specify a location for each 4-letter prefix.  Add further locations by following the format of lines 5 and 6.


Const HKEY_LOCAL_MACHINE = &H80000002
 
set objLocations = CreateObject("Scripting.Dictionary")
objLocations.CompareMode = VBTextCompare
objLocations.Add "SCAB", "\\SCAB001\custom\config.xml"
objLocations.Add "USMD", "\\USMD005\custom\config.xml"
 
Set WSHShell = CreateObject("WScript.Shell")
strComputer = WshShell.ExpandEnvironmentStrings("%computername%")
strPrefix = Left(strComputer, 4)
strLocation = objLocations.Item(strPrefix)
 
Set objRegistry = GetObject _
    ("winmgmts:\\" & strComputer & "\root\default:StdRegProv")
 
strKeyPath = "Software\Custom"
strValueName = "Config"
strData = strLocation
 
errReturn = objRegistry.SetStringValue _
    (HKEY_LOCAL_MACHINE, strKeyPath, strValueName, strData)

Open in new window

0
 

Author Comment

by:Lorrec
ID: 21782369
I really appreciate this. You pointed me in the right direction. Thank you for the help.
0
 

Author Closing Comment

by:Lorrec
ID: 31467007
Thanks again for all the help.
0

Featured Post

Independent Software Vendors: 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

Welcome, welcome!  If you are new to the series and haven't been following along, please take a brief moment to review the first three installments: Part 1 (http://www.experts-exchange.com/Programming/Languages/Visual_Basic/VB_Script/A_266-VBScri…
This script will sweep a range of IP addresses (class c only, 255.255.255.0) and report to a log the version of office installed. What it does: 1.)      Creates log file in the directory the script is run from (if it doesn't already exist) 2.)      Sweep…
Do you want to know how to make a graph with Microsoft Access? First, create a query with the data for the chart. Then make a blank form and add a chart control. This video also shows how to change what data is displayed on the graph as well as form…
In this video, Percona Solutions Engineer Barrett Chambers discusses some of the basic syntax differences between MySQL and MongoDB. To learn more check out our webinar on MongoDB administration for MySQL DBA: https://www.percona.com/resources/we…

715 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