'*******************窗体上有一个combobox************************
Private Sub Combo1_Click()
Dim rret As Long, ret As Long, hKey As Long, lenData As Long, typeData As Long
      
   
    rret = RegOpenKey(HKEY_CURRENT_USER, "Software\SetValue", hKey)
    If rret = 0 Then
      ret = RegQueryValueEx(hKey, "IMEName", 0, typeData, ByVal vbNullString, lenData)
      If ret = 0 Then
        RegSetValueEx hKey, "IMEName", 0, REG_SZ, ByVal Combo1.Text, lenData
      Else
        RegCreateKey HKEY_CURRENT_USER, "Software\SetValue", hKey
        RegSetValueEx hKey, "IMEName", 0, REG_SZ, ByVal Combo1.Text, lenData
        RegSetValueEx hKey, "IMEindex", 0, REG_SZ, ByVal CStr(Combo1.ListIndex), 1
      End If
      ret = RegQueryValueEx(hKey, "IMEindex", 0, typeData, ByVal vbNullString, lenData)
      If ret = 0 Then
        RegSetValueEx hKey, "IMEindex", 0, REG_SZ, Combo1.ListIndex, lenData
      Else
         RegCreateKey HKEY_CURRENT_USER, "Software\SetValue", hKey
        RegSetValueEx hKey, "IMEName", 0, REG_SZ, ByVal Combo1.Text, lenData
        RegSetValueEx hKey, "IMEindex", 0, REG_SZ, ByVal CStr(Combo1.ListIndex), 1
      End If
    End If
     RegCloseKey hKey
End Sub
Private Sub Form_Load()
Combo1.AddItem "王码五笔型86版"
Combo1.AddItem "王码五笔型98版"
End Sub'*******************setvalue.bas ************************Option Explicit
Public Const HKEY_CLASSES_ROOT = &H80000000
Public Const HKEY_CURRENT_USER = &H80000001
Public Const HKEY_LOCAL_MACHINE = &H80000002
Public Const HKEY_USERS = &H80000003
Public Const HKEY_PERFORMANCE_DATA = &H80000004
Public Const HKEY_CURRENT_CONFIG = &H80000005
Public Const HKEY_DYN_DATA = &H80000006Public Const REG_NONE = 0
Public Const REG_SZ = 1
Public Const REG_EXPAND_SZ = 2
Public Const REG_BINARY = 3
Public Const REG_DWORD = 4
Public Const REG_DWORD_BIG_ENDIAN = 5
Public Const REG_MULTI_SZ = 7
'注意下面的函数声明要在一行内写完
Declare Function RegOpenKey Lib "advapi32.dll" Alias "RegOpenKeyA" (ByVal hKey As Long, ByVal lpSubKey As String, phkResult As Long) As Long
Declare Function RegCreateKey Lib "advapi32.dll" Alias "RegCreateKeyA" (ByVal hKey As Long, ByVal lpSubKey As String, phkResult As Long) As Long
Declare Function RegCloseKey Lib "advapi32.dll" (ByVal hKey As Long) As Long
Declare Function RegSetValueEx Lib "advapi32.dll" Alias "RegSetValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal Reserved As Long, ByVal dwType As Long, lpData As Any, ByVal cbData As Long) As Long
Declare Function RegQueryValueEx Lib "advapi32.dll" Alias "RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, lpType As Long, lpData As Any, lpcbData As Long) As Long
Declare Function RegSetValue Lib "advapi32.dll" Alias "RegSetValueA" (ByVal hKey As Long, ByVal lpSubKey As String, ByVal dwType As Long, ByVal lpData As String, ByVal cbData As Long) As Long

解决方案 »

  1.   

    Option Explicit'关于读写修改注册表的API函数
    '---------------------------------------------------------------------------------Public Const HKEY_CLASSES_ROOT = &H80000000
    Public Const HKEY_CURRENT_CONFIG = &H80000005
    Public Const HKEY_CURRENT_USER = &H80000001
    Public Const HKEY_DYN_DATA = &H80000006
    Public Const HKEY_LOCAL_MACHINE = &H80000002
    Public Const HKEY_PERFORMANCE_DATA = &H80000004
    Public Const HKEY_USERS = &H8000000
    Public Const REG_SZ = 1
    Public Const ERROR_NONE = 0Public Const ERROR_SUCCESS = 0&
    Global Const ERROR_BADDB = 1
    Global Const ERROR_BADKEY = 2
    Global Const ERROR_CANTOPEN = 3
    Global Const ERROR_CANTREAD = 4
    Global Const ERROR_CANTWRITE = 5
    Global Const ERROR_OUTOFMEMORY = 6
    Global Const ERROR_INVALID_PARAMETER = 7
    Global Const ERROR_ACCESS_DENIED = 8
    Global Const ERROR_INVALID_PARAMETERS = 87
    Global Const ERROR_NO_MORE_ITEMS = 259Public Const REG_BINARY = 3
    Public Const REG_CREATED_NEW_KEY = &H1
    Public Const REG_DWORD = 4
    Public Const REG_DWORD_BIG_ENDIAN = 5
    Public Const REG_DWORD_LITTLE_ENDIAN = 4
    Public Const REG_EXPAND_SZ = 2
    Public Const REG_FULL_RESOURCE_DESCRIPTOR = 9
    Public Const REG_LINK = 6
    Public Const REG_MULTI_SZ = 7
    Public Const REG_NONE = 0
    Public Const REG_NOTIFY_CHANGE_ATTRIBUTES = &H2
    Public Const REG_NOTIFY_CHANGE_LAST_SET = &H4
    Public Const REG_NOTIFY_CHANGE_NAME = &H1
    Public Const REG_NOTIFY_CHANGE_SECURITY = &H8
    Public Const REG_OPENED_EXISTING_KEY = &H2
    Public Const REG_OPTION_BACKUP_RESTORE = 4
    Public Const REG_OPTION_CREATE_LINK = 2
    Public Const REG_OPTION_NON_VOLATILE = 0
    Public Const REG_OPTION_RESERVED = 0
    Public Const REG_OPTION_VOLATILE = 1
    Public Const REG_REFRESH_HIVE = &H2
    Public Const REG_RESOURCE_LIST = 8
    Public Const REG_RESOURCE_REQUIREMENTS_LIST = 10
    Public Const REG_WHOLE_HIVE_VOLATILE = &H1
    Public Const REG_LEGAL_CHANGE_FILTER = (REG_NOTIFY_CHANGE_NAME Or REG_NOTIFY_CHANGE_ATTRIBUTES Or REG_NOTIFY_CHANGE_LAST_SET Or REG_NOTIFY_CHANGE_SECURITY)
    Public Const REG_LEGAL_OPTION = (REG_OPTION_RESERVED Or REG_OPTION_NON_VOLATILE Or REG_OPTION_VOLATILE Or REG_OPTION_CREATE_LINK Or REG_OPTION_BACKUP_RESTORE)Public Const READ_CONTROL = &H20000
    Public Const STANDARD_RIGHTS_ALL = &H1F0000
    Public Const STANDARD_RIGHTS_READ = (READ_CONTROL)
    Public Const SYNCHRONIZE = &H100000
    Public Const STANDARD_RIGHTS_WRITE = (READ_CONTROL)Public Const KEY_CREATE_LINK = &H20
    Public Const KEY_CREATE_SUB_KEY = &H4
    Public Const KEY_ENUMERATE_SUB_KEYS = &H8
    Public Const KEY_EVENT = &H1Public Const KEY_NOTIFY = &H10
    Public Const KEY_QUERY_VALUE = &H1
    Public Const KEY_READ = ((STANDARD_RIGHTS_READ Or KEY_QUERY_VALUE Or KEY_ENUMERATE_SUB_KEYS Or KEY_NOTIFY) And (Not SYNCHRONIZE))
    Public Const KEY_SET_VALUE = &H2
    Public Const KEY_WRITE = ((STANDARD_RIGHTS_WRITE Or KEY_SET_VALUE Or KEY_CREATE_SUB_KEY) And (Not SYNCHRONIZE))Public Const KEY_EXECUTE = (KEY_READ)
    Public Const KEY_ALL_ACCESS = ((STANDARD_RIGHTS_ALL Or KEY_QUERY_VALUE Or KEY_SET_VALUE Or KEY_CREATE_SUB_KEY Or KEY_ENUMERATE_SUB_KEYS Or KEY_NOTIFY Or KEY_CREATE_LINK) And (Not SYNCHRONIZE))Public Declare Function RegCloseKey Lib "advapi32.dll" (ByVal hKey As Long) As Long
    Public Declare Function RegCreateKey Lib "advapi32.dll" Alias "RegCreateKeyA" (ByVal hKey As Long, ByVal lpSubKey As String, phkResult As Long) As Long
    Public Declare Function RegCreateKeyEx Lib "advapi32.dll" Alias "RegCreateKeyExA" (ByVal hKey As Long, ByVal lpSubKey As String, ByVal Reserved As Long, ByVal lpClass As String, ByVal dwOptions As Long, ByVal samDesired As Long, ByVal lpSecurityAttributes As Any, phkResult As Long, lpdwDisposition As Long) As Long
    Public Declare Function RegDeleteKey Lib "advapi32.dll" Alias "RegDeleteKeyA" (ByVal hKey As Long, ByVal lpSubKey As String) As Long
    Public Declare Function RegDeleteValue Lib "advapi32.dll" Alias "RegDeleteValueA" (ByVal hKey As Long, ByVal lpValueName As String) As Long
    Public Declare Function RegEnumKey Lib "advapi32.dll" Alias "RegEnumKeyA" (ByVal hKey As Long, ByVal dwIndex As Long, ByVal lpName As String, ByVal cbName As Long) As Long
    Public Declare Function RegOpenKey Lib "advapi32.dll" Alias "RegOpenKeyA" (ByVal hKey As Long, ByVal lpSubKey As String, phkResult As Long) As Long
    Public Declare Function RegOpenKeyEx Lib "advapi32.dll" Alias "RegOpenKeyExA" (ByVal hKey As Long, ByVal lpSubKey As String, ByVal ulOptions As Long, ByVal samDesired As Long, phkResult As Long) As LongPublic Declare Function RegQueryValueExString Lib "advapi32.dll" Alias "RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, lpType As Long, ByVal lpData As String, lpcbData As Long) As Long
    Public Declare Function RegQueryValueExLong Lib "advapi32.dll" Alias "RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, lpType As Long, lpData As Long, lpcbData As Long) As Long
    Public Declare Function RegQueryValueExNULL Lib "advapi32.dll" Alias "RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, lpType As Long, ByVal lpData As Long, lpcbData As Long) As Long
    Public Declare Function RegSetValueExString Lib "advapi32.dll" Alias "RegSetValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal Reserved As Long, ByVal dwType As Long, ByVal lpValue As String, ByVal cbData As Long) As Long
    Public Declare Function RegSetValueExLong Lib "advapi32.dll" Alias "RegSetValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal Reserved As Long, ByVal dwType As Long, lpValue As Long, ByVal cbData As Long) As Long
    Public Declare Function RegQueryValueEx Lib "advapi32.dll" Alias "RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, lpType As Long, lpData As Any, lpcbData As Long) As Long
      

  2.   

    Public Function EnumKey(hMainKey As Long, sSubKey As String, lIndex As Long, lpStr As String) As Boolean
    'EnumKey函数打开有hMainKey主键和sSubKey子键指定的注册键,lIndex为要查询的子键值
    '的索引,lpStr为放置子键值的字符串缓冲,如果要查询一个键值的所有子键,只要将lIndex
    '首先设置为0,然后将lIndex递增1再调用EnumKey函数,直到函数返回0为止
        Dim hKey As Long    '打开键的句柄
        Dim i As Long
        
        If RegOpenKey(hMainKey, sSubKey, hKey) = ERROR_SUCCESS Then
            lpStr = Space(255) + Chr(0)
    '        Debug.Print Len(lpStr)
            If RegEnumKey(hKey, lIndex, lpStr, Len(lpStr)) = ERROR_SUCCESS Then
                EnumKey = True
            Else
                EnumKey = False
            End If
        Else
            EnumKey = False
        End If
        RegCloseKey hKey
    End FunctionPublic Function DeleteKey(lPredefinedKey As Long, sKeyName As String)
    'DeleteKey函数打开有hPredfineKeyKey主键和sKeyName子键指定的注册键,再将此子键删除
        Dim lRetVal As Long
        Dim hKey As Long         '打开键的句柄
            
        lRetVal = RegOpenKeyEx(lPredefinedKey, sKeyName, 0, KEY_ALL_ACCESS, hKey)
        lRetVal = RegDeleteKey(lPredefinedKey, sKeyName)
        RegCloseKey (hKey)
    End FunctionPublic Function DeleteValue(lPredefinedKey As Long, sKeyName As String, sValueName As String)
    'DeleteValue函数删除一个值
        Dim lRetVal As Long
        Dim hKey As Long     '打开键的句柄
        
        lRetVal = RegOpenKeyEx(lPredefinedKey, sKeyName, 0, KEY_ALL_ACCESS, hKey)
        lRetVal = RegDeleteValue(hKey, sValueName)
        RegCloseKey (hKey)
    End FunctionPublic Function SetValueEx(ByVal hKey As Long, sValueName As String, lType As Long, vValue As Variant) As Long
    'SetValueEx函数设置值
    '如果参数为REG_SZ则设置的值为字符串
    '如果参数为REG_WORD设置的值为整数值
        Dim lValue As Long
        Dim sValue As String    Select Case lType
            Case REG_SZ
                sValue = vValue
                SetValueEx = RegSetValueExString(hKey, sValueName, 0&, lType, sValue, LenB(sValue))
            Case REG_DWORD
                lValue = vValue
                SetValueEx = RegSetValueExLong(hKey, sValueName, 0&, lType, lValue, 4)
        End Select
    End FunctionPublic Function CreateNewKey(lPredefinedKey As Long, sNewKeyName As String)
        ' Description:
        ' 这个函数建立一个新的键
        Dim hNewKey As Long         '打开新键的句柄
        Dim lRetVal As Long
        
        lRetVal = RegCreateKeyEx(lPredefinedKey, sNewKeyName, 0&, vbNullString, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, 0&, hNewKey, lRetVal)
        RegCloseKey (hNewKey)
    End FunctionPublic Function SetKeyValue(lPredefinedKey As Long, sKeyName As String, sValueName As String, vValueSetting As Variant, lValueType As Long)
        Dim lRetVal As Long
        Dim hKey As Long         '打开键的句柄
        
        lRetVal = RegOpenKeyEx(lPredefinedKey, sKeyName, 0, KEY_ALL_ACCESS, hKey)
        lRetVal = SetValueEx(hKey, sValueName, lValueType, vValueSetting)
        RegCloseKey (hKey)
    End FunctionPublic Function RegQueryStringValue(ByVal hKey As Long, ByVal strValueName As String) As String
        Dim lResult As Long, lValueType As Long, strBuf As String, lDataBufSize As Long
        lResult = RegQueryValueEx(hKey, strValueName, 0, lValueType, ByVal 0, lDataBufSize)
        If lResult = 0 Then
            If lValueType = REG_SZ Then
                strBuf = String(lDataBufSize, Chr$(0))
                lResult = RegQueryValueEx(hKey, strValueName, 0, 0, ByVal strBuf, lDataBufSize)
                If lResult = 0 Then RegQueryStringValue = Left$(strBuf, InStr(1, strBuf, Chr$(0)) - 1)
            ElseIf lValueType = REG_BINARY Then
                Dim strData As Integer
                lResult = RegQueryValueEx(hKey, strValueName, 0, 0, strData, lDataBufSize)
                If lResult = 0 Then RegQueryStringValue = strData
            End If
        End If
    End FunctionPublic Function QueryValue(lPredefinedKey As Long, sKeyName As String, sValueName As String)
        Dim Ret
        RegOpenKey lPredefinedKey, sKeyName, Ret
        QueryValue = RegQueryStringValue(Ret, sValueName)
        RegCloseKey Ret
    End Function
      

  3.   

    用法:Option ExplicitConst strKey As String = "Software\SetValue"Private Sub Combo1_Click()
        SetKeyValue HKEY_CURRENT_USER, strKey, "IMEName", Combo1.Text, REG_SZ
        SetKeyValue HKEY_CURRENT_USER, strKey, "IMEindex", Combo1.ListIndex, REG_SZ
    End SubPrivate Sub Form_Load()
        Combo1.AddItem "王码五笔型86版"
        Combo1.AddItem "王码五笔型98版"
        CreateNewKey HKEY_CURRENT_USER, strKey
    End Sub
      

  4.   

    一个函数的申明当然要在一行完成,
    不过如果是在完不成可以在一行后面加上[空格]_(就是空格和一个下横线)如下:
    Declare Function RegOpenKey Lib "advapi32.dll" Alias "RegOpenKeyA" (ByVal hKey As Long, _
      ByVal lpSubKey As String, phkResult As Long) As Long
    Declare Function RegCreateKey Lib "advapi32.dll" Alias "RegCreateKeyA" (ByVal hKey As  _
    Long, ByVal lpSubKey As String, phkResult As Long) As Long
    Declare Function RegCloseKey Lib "advapi32.dll" (ByVal hKey As Long) As Long
    Declare Function RegSetValueEx Lib "advapi32.dll" Alias "RegSetValueExA" (ByVal hKey  _
    As Long, ByVal lpValueName As String, ByVal Reserved As Long, ByVal dwType As Long,  _
    lpData As Any, ByVal cbData As Long) As Long