如何使用VBA在其他工作簿中插入控件并写入代码

 我来答
百度网友5219427
2017-07-29 · TA获得超过1652个赞
知道小有建树答主
回答量:963
采纳率:53%
帮助的人:435万
展开全部
希望楼主耐心揣摩,举一反三
Sub 建立窗体并运行()
    Dim TempForm As Object '采用后期绑定
    Application.VBE.MainWindow.Visible = False  '防止窗口闪动
     Set TempForm = ThisWorkbook.VBProject.VBComponents.Add(3)   '   建立窗体
    With TempForm
        .Properties("Caption") = "智能输入"
        .Properties("Width") = 100
        .Properties("Height") = 100
    End With
   With TempForm.Designer.Controls.Add("forms.ComboBox.1") '创建组合框
        .Left = 10
        .Top = 15
    End With
    With TempForm.Designer.Controls.Add("forms.CommandButton.1") '创建一个按钮
        .Left = 10
        .Top = 45
        .Caption = "输入当前日期"
    End With
    With TempForm.CodeModule  '   为窗体添加代码
        .InsertLines .CountOfLines + 1, "Private Sub UserForm_Activate()"
        .InsertLines .CountOfLines + 2, "Me.ComboBox1.List = Array(""一月"", ""二月"", ""三月"", ""四月"", ""五月"", ""六月"", ""七月"", ""八月"", ""九月"", ""十月"", ""十一月"", ""十二月"")"
        .InsertLines .CountOfLines + 3, "Me.ComboBox1 = WorksheetFunction.Text(VBA.Month(Date), ""[DBNum1][$-804]0月"")"
        .InsertLines .CountOfLines + 4, "End Sub"
        .InsertLines .CountOfLines + 5, "Private Sub ComboBox1_Change()"
        .InsertLines .CountOfLines + 6, "If TypeName(ActiveCell) = ""Range"" Then ActiveCell = Me.ComboBox1.Text"
        .InsertLines .CountOfLines + 7, "End Sub"
        .InsertLines .CountOfLines + 8, "Private Sub CommandButton1_Click()"
        .InsertLines .CountOfLines + 9, "If TypeName(ActiveCell) = ""Range"" Then ActiveCell = date"
        .InsertLines .CountOfLines + 10, "End Sub"
        End With
    VBA.UserForms.Add(TempForm.Name).Show    '   显示窗体
    ThisWorkbook.VBProject.VBComponents.Remove TempForm '   运行完毕删除窗体
End Sub
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式