Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 3412|回复: 3

[已解决]如何根据第一个复合框的内容决定第二个复合框的下拉幅度?

[复制链接]
发表于 2010-3-14 20:40 | 显示全部楼层 |阅读模式

 如何根据第一个复合框的内容决定第二个复合框的下拉幅度?

R5oh5z5C.zip (9.18 KB, 下载次数: 43)
发表于 2010-3-14 20:51 | 显示全部楼层    本楼为最佳答案   

Private Sub ComboBox1_Change()
Dim x%
If Me.ComboBox1.Value = "张三" Then
            x = 13
        Else
            x = 15
        End If
        For y = 1 To x
            ComboBox2.AddItem Sheets("sheet1").Cells(y, 2)
        Next y
End Sub

Private Sub UserForm_Initialize()
    Dim m%, n%, x%, y%
    With Sheets("sheet1")
        m = .Range("A65536").End(xlUp).Row
        For n = 1 To m
            ComboBox1.AddItem .Cells(n, 1)
        Next n
    End With
End Sub

回复

使用道具 举报

发表于 2010-3-14 20:55 | 显示全部楼层


Private Sub ComboBox1_Click()
Me.ComboBox2.Clear
If Me.ComboBox1.Value = "张三" Then
  x = 12
Else
 x = 17
End If
With Sheets("sheet1")
    
        For y = 1 To x
            ComboBox2.AddItem .Cells(y, 2)
        Next y
End With
End Sub

Private Sub UserForm_Initialize()
    Dim m%, n%, x%, y%
    With Sheets("sheet1")
        m = .Range("A65536").End(xlUp).Row
        For n = 1 To m
            ComboBox1.AddItem .Cells(n, 1)
        Next n
       
    End With
   
End Sub

回复

使用道具 举报

发表于 2010-3-14 21:01 | 显示全部楼层

可以这样不?

Private Sub ComboBox1_Change()
If ComboBox1.Value = "张三" Then
   ComboBox2.RowSource = "sheet1!b1:b12"
Else
   ComboBox2.RowSource = "sheet1!b1:b15"
End If
End Sub
Private Sub UserForm_Initialize()
    ComboBox1.RowSource = "sheet1!A1:A2"
    ComboBox2.RowSource = "sheet1!b1:b17"
End Sub

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-4-29 11:42 , Processed in 0.271637 second(s), 10 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表