Word窗体联动Excel实现级联组合框

在Word中的使用用户窗体(UserForm)定制界面如下图所示,其中控件如下(忽略Label控件):

  • CompanyName 组合框
  • Attention 组合框
  • CommandButton1 按钮

现在需要实现级联组合框效果,即用户在 CompanyName 组合框中选中如何一个Company,第二个组合框(Attention)加载相应对应的内容,其数据来自于Excel文件(FileLink.xlsx)中的数据表,如下图所示。

vb 复制代码
Dim arrData As Variant
Sub LoadData()
    Dim xlApp As Object, xlBook As Object, isNewApp As Boolean
    On Error Resume Next
    Set xlApp = GetObject(, "Excel.Application")
    If Err Then
        Set xlApp = CreateObject("Excel.Application")
        isNewApp = True
    End If
    On Error GoTo 0
    Dim sPath As String: sPath = ThisDocument.Path & "\"
    Set xlBook = xlApp.Workbooks.Open(sPath & "FileLink.xlsx")
    arrData = xlBook.sheets(1).usedrange.Value
    xlBook.Close False
    If isNewApp Then xlApp.Quit
End Sub
Private Sub UserForm_Initialize()
    Call LoadData
    Dim arr(), i As Long
    ReDim arr(1 To UBound(arrData) - 1)
    For i = 2 To UBound(arrData)
        arr(i - 1) = arrData(i, 1)
    Next
    Me.CompanyName.List = arr
End Sub
Private Sub CompanyName_Change()
    Me.Attention.Clear
    Dim sComName As String: sComName = Me.CompanyName.Value
    Dim i As Long, j As Long, r As Long, arr()
    ReDim arr(1 To UBound(arrData, 2) - 1)
    For i = 2 To UBound(arrData)
        If sComName = arrData(i, 1) Then
            For j = 2 To UBound(arrData, 2)
                If Len(arrData(i, j)) = 0 Then
                    Exit For
                Else
                    r = r + 1
                    arr(r) = arrData(i, j)
                End If
            Next
            If r > 0 Then
                ReDim Preserve arr(1 To r)
                Me.Attention.List = arr
            End If
        End If
    Next
End Sub
Private Sub CommandButton1_Click()
    Unload Me
End Sub

第1行代码声明模块级别变量,用于保存Excel的数据表。

如果用户每次改变CompanyName组合框,都运行代码打开Excel读取数据表,再更新Attention控件的下拉列表,创建Excel应用程序并打开Excel文件将消耗较多时间,程序可能会因此而出现卡顿。

第3~17行代码将Excel数据表加载到数组中,后续代码可用直接读取内存数组中的数据,这样可用使得程序代码的效率更高。

第5行代码忽略系统错误。

第6行代码获取Excel应用程序,如果用户没有打开Excel,那么此行代码将产生运行时错误。

第7行代码判断是否产生了运行时错误。

第8行代码创建新的Excel应用程序实例。

第9行代码设置标志变量,指明Excel应用程序为新建实例。

第12行代码获取当前文档的目录。

第13行代码打开同一目录中的Excel文件FileLink.xlsx。

第14行代码将第一个工作表中的数据表加载到数组中。

第15行代码关闭Excel文件。

对于第8行代码新建的Excel应用程序,第16行代码将关闭Excel应用程序。

第18~26行代码为UserForm的初始化事件代码。

第19行代码调用LoadData加载数据到数组中。

第21行代码为动态数组arr分配空间。

第22~24行代码将Company列表读取到数组中。

第25行代码设置CompanyName组合框的下拉列表。

第27~48行代码为CompanyName组合框的Change事件代码。

第28行代码清空Attention组合框下拉列表。

第29行代码读取CompanyName组合框的值(用户选中的Company)。

第31行代码为动态数组arr分配空间。

第32~47行代码循环遍历arrData数组。

第33行代码判断Company是否匹配。

第34~41行代码将对应于指定Company的数据行加载到数组arr中。

第35行代码判断单元格内容是否为空。

如果为空,第36行代码代码退出For循环,否则,第39行代码将单元格内容添加到数组arr中。

第43行代码重新分配数组arr的内存,去除数组末尾可能存在的空值,否则第二个组合框下拉列表中将出现空值。

第44行代码更新Attention组合框下拉列表。

第49~51行代码为CommandButton1按钮控件的Click事件代码。

第50行代码关闭窗体。

相关推荐
_处女座程序员的日常11 小时前
如何预览常见格式word、excel、ppt、图片等格式的文档
前端·javascript·word·excel·开源软件
学会用脚编程1 天前
word转Pdf,在window正常,放在linux服务器上就转出来中文是空白
pdf·word
跟着珅聪学java1 天前
在Java中判断Word文档中是否包含表格并读取表格内容,可以使用Apache POI库教程
java·开发语言·word
CodeCraft Studio3 天前
国产化Excel处理控件Spire.XLS教程:如何使用 Java 将 TXT 文本转换为 Excel 表格
java·word·excel·spire·文档格式转换·txt转excel
开开心心就好3 天前
电子报纸离线保存:一键下载多报PDF工具
网络·笔记·macos·pdf·word·音视频·phpstorm
书中自有妍如玉3 天前
Node.Js 实现模板生成Word、Word转Pdf文件、Excel生成、上传和下载
pdf·node.js·word
格兰芬多呼神护卫4 天前
python实现Latex格式的公式转OMML并写入word
python·c#·word
不坑老师5 天前
利用不坑盒子在WPS中插入网页,放映的电脑无需安装插件,直接就能显示网页!
microsoft·word·powerpoint·wps
ljh_learn_from_base6 天前
【spring boot 使用apache poi 生成和处理word 文档】
java·spring boot·word·apache
2501_920955576 天前
Word崩溃打不开?实测三款Word文档修复工具!
word