2012-10-12 144 views
0

我想在另一个列表中根据用户选择填写下拉列表。在线找不到与其相关的任何内容。基于另一个选择列表动态更新选择列表

我有一个名为lookupDept包含下表工作簿:

A B 
== ============================== 
BS Business School 
CG Chemical Engineering 

其中列A具有定义的名称DEPTCODE塔B具有定义的名称DEPTNAME。我有一个名为lookupModule一个第二个工作簿包含如下表:

A  B             C 
====== ================================================== == 
BSA005 Organisational Behaviour       BS 
BSA007 Skills for Study         BS 
CGA001 Fluid Mechanics I MEng & BEng Status    CG 
CGA002 Stagewise Processes         CG 

我试图更新cbo_moduleCode我的形式来选择的范围中列AlookupDept列相匹配C in lookupModule。这是我使用的代码:

因此,如果用户挑选BS - 商学院形式(这从lookupDept工作簿中提取,我想包含BS所有字段列C 。在lookupModule工作簿中选择的。这是我使用至今代码:。

Private Sub UserForm_Initialize() 

    Dim c_deptCode As Range 
    Dim c_deptName As Range 

    Dim deptCodes As Variant 
    Dim deptNames As Variant 

    Dim ws_dept As Worksheet 
    Dim ws_misc As Worksheet 
    Set ws_dept = Worksheets("lookupDept") 
    Set ws_misc = Worksheets("lookupMisc") 

    ' Assign each range to an array containing the values 
    deptCodes = Choose(1, ws_dept.Range("deptCode")) 
    deptNames = Choose(1, ws_dept.Range("deptName")) 

    ' Create deptcode+deptname cbo 
    For i = 1 To ws_dept.Range("deptCode").Rows.Count 
     CombinedName = deptCodes(i, 1) & " - " & deptNames(i, 1) 
     cbo_deptCode.AddItem CombinedName 
    Next i 

End Sub 

回答

1

你可以尝试添加对飞的项目一旦选择了第一个组合框此代码是一个样本可能带领您朝着正确的方向发展:

Private Sub cbo_deptCode_Change() 
Dim lLoop As Long, rgLoop As range 

For lLoop = 1 To Me.cbo_moduleCode.ListCount 

    Me.cbo_moduleCode.RemoveItem 0 

Next lLoop 

Sheets("lookupModule").[a1].CurrentRegion.AutoFilter 
Sheets("lookupModule").[a1].CurrentRegion.AutoFilter Field:=3, Criteria1:=Left(Me.cbo_deptCode.Value, 2) 

For Each rgLoop In Sheets("lookupModule").[a1].CurrentRegion.Offset(1).SpecialCells(xlCellTypeVisible).Columns(1).Cells 
    If Len(rgLoop) > 0 Then 
     Me.cbo_moduleCode.AddItem rgLoop & " - " & rgLoop.Offset(, 1) 
    End If 
Next rgLoop 

End Sub 
+0

是否有其他方法,您不必使用自动过滤器? – methuselah

+0

lookupModule – methuselah

+0

只有一行时,你看到的结果是什么?是否有匹配的行,或根本没有? – nutsch

相关问题