Excel精英培训网

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

[已解决]EXCEL-如何根据数据自动变换下拉列表可选数据

[复制链接]
发表于 2014-10-21 15:37 | 显示全部楼层 |阅读模式
说明-Sheet“数据源”:
A列与B列的关系,是从属关系,即B列从属于A列。
比如A是10301110,那么B列对应的就是1001、1002、2001、2002这四个值。
但是B列的值,对于不同A列值,有可能是重复的,比如10301110和12102110下面都有1001。

说明-Sheet“用户填写 ”:
想要实现的效果是:用户在“用户填写”Sheet页,选了Value1(A列)的值之后,B列的下拉列表可选值只包含Value1下面的Value2。
比如在“用户填写”Sheet页,A列选了10301110,B列下拉列表只能选到1001、1002、2001、2002。

无论是公式还是VBA,困扰我好久了,求大神!!!!!
PS.本人不会VBA,若是通过VBA解决,求VBA代码!!!!

最佳答案
2014-10-21 16:26
本帖最后由 zjdh 于 2014-10-21 16:32 编辑

下拉列表.rar (21.63 KB, 下载次数: 192)

下拉列表-请教.rar

13.89 KB, 下载次数: 24

excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2014-10-21 16:26 | 显示全部楼层    本楼为最佳答案   
本帖最后由 zjdh 于 2014-10-21 16:32 编辑

下拉列表.rar (21.63 KB, 下载次数: 192)
回复

使用道具 举报

发表于 2014-10-21 16:43 | 显示全部楼层
Private Sub Worksheet_Change(ByVal T As Range)
If T.Count <> 1 Then Exit Sub
If T.Column <> 1 Then Exit Sub
If T = "" Then Exit Sub
Application.EnableEvents = 0
s$ = T
Dim c1 As Range, c2 As Range
With Sheets("数据源")
    Set c1 = .Range("A:A").Find(s, , , xlWhole, , 1)
    If Not c1 Is Nothing Then
       Set c2 = .Range("A:A").Find(s, , , xlWhole, , 2)
       s = "=数据源!" & c1(1, 2).Address & ":" & c2(1, 2).Address
       With T(1, 2).Validation
           .Delete
           .Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:= _
            xlBetween, Formula1:=s
        .IgnoreBlank = True
        .InCellDropdown = True
       End With
       Set c1 = Nothing
       Set c2 = Nothing
    End If
End With
Application.EnableEvents = 1
End Sub
回复

使用道具 举报

 楼主| 发表于 2014-10-21 20:01 | 显示全部楼层
两位太帅!可以有两个最佳答案吗?{:211:}
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-3-29 13:51 , Processed in 0.621365 second(s), 12 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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