使用VBA,如何在UserForm中创建传递RecordSet字段的CheckBox

时间:2015-03-05 18:31:07

标签: excel vba dynamic checkbox userform

我有一个命令按钮,需要在下面动态显示用户表单,并从记录集中提取列标题作为复选框选项。

Table Range

User Form

我有用于初始化的代码如下

Private Sub UserForm_Initialize()
    Set xl1 = Excel.Application
    Dim xlXML As Object
    Dim adoRecordset As Object
    Dim rng As Range
    Dim recordCount1 As Long
    Dim Fieldcount1 As Long
    xl1.ThisWorkbook.Sheets(2).Activate
    Set rng = xl1.ThisWorkbook.Sheets(2).Range("A1:I15")
    Set adoRecordset = CreateObject("ADODB.Recordset")
    Set xlXML = CreateObject("MSXML2.DOMDocument")
    xlXML.LoadXML rng.Value(xlRangeValueMSPersistXML)
    adoRecordset.Open xlXML
    adoRecordset.MoveFirst
    Fieldcount1 = adoRecordset.Fields.Count
    Dim i As Long
    Dim chkBox As CheckBox
    For i = 1 To Fieldcount1
        Set chkBox = UserForm1.Controls.Add("Forms.Checkbox.1", "Checkbox" & i)
        chkBox.Caption = adoRecordset.Fields(i - 1)
        chkBox.Value = False
        chkBox.Top = (chkBox.Height + Spacing) * (i - 1)
    Next i

End Sub

我收到“运行时错误'13':类型不匹配”错误

请你帮我解决一下。

我是Scripting的初学者

1 个答案:

答案 0 :(得分:0)

问题出在变量声明中。你需要:

Dim chkBox As MSForms.CheckBox