使用VBA实现Excel下拉多选

扩展 专栏收录该内容
14 篇文章 0 订阅

Excel的下拉多选

新项目需要excel导入时的下拉多选框

Excel表格下拉单选很简单,先给表格做成单选。参照
[excel怎么设置下拉选择项] (https://jingyan.baidu.com/article/1876c85255d929890a13767d.html)
Excel要想做成多选首先需要启用宏,如果Excel中没有宏,需要下载

下载安装

安装完之后重启Excel。

在当前sheet上点击开发工具,再点击VB编辑器
左侧project是你的Excel表格,表格下对应每一个sheet。双击你想要修改的sheet即可打开下图VB编辑器。粘贴下方代码。

点击宏,创建新宏如下图操作。
(宏名随意输入)

粘代码

Sub Worksheet_Change(ByVal Target As Range)
'让数据有效性选择 可以多选,不可重复
Dim rngDV As Range
Dim oldVal As String

Dim newVal As String
If Target.Count > 1 Then GoTo exitHandler

On Error Resume Next
Set rngDV = Cells.SpecialCells(xlCellTypeAllValidation)
On Error GoTo exitHandler

If rngDV Is Nothing Then GoTo exitHandler

If Intersect(Target, rngDV) Is Nothing Then
'do nothing

Else
Application.EnableEvents = False
newVal = Target.Value
If Target.Column = 2 Or 3 Or 6 Then '数字是你想要多选的列是多少,多个用or连接。
Application.Undo
oldVal = Target.Value
Target.Value = newVal
If oldVal = "" Then
Else
If newVal = "" Then
Else '去除重复的字段
       If InStr(1, oldVal, newVal) <> 0 Then
          If InStr(1, oldVal, newVal) + Len(newVal) - 1 = Len(oldVal) Then '最后一个选项重复
            Target.Value = Left(oldVal, Len(oldVal) - Len(newVal) - 1)
          Else
            Target.Value = Replace(oldVal, newVal & ",", "") '不是最后一个选项重复的时候处理逗号
          End If
        Else '不是重复选项就视同增加选项
Target.Value = oldVal _
& "," & newVal '可以是任意符号隔开
End If
End If
End If
End If
End If
exitHandler:
Application.EnableEvents = True
End Sub
提示:在“ ' ”后面的是注释可以删除
保存一下点击运行-->运行子过程/用户窗体,点击你创建的宏后,点击右侧运行。

结果如下图
在这里插入图片描述

  • 6
    点赞
  • 2
    评论
  • 24
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值