优秀的编程知识分享平台

网站首页 > 技术文章 正文

使用VBA为你的EXCEL添加聚光灯效果,不破坏原数据底色

nanyue 2024-10-08 05:42:47 技术文章 9 ℃

当我们使用的EXCEL有大量数据时,选中某一数据却无法快速定位它所属的字段信息,这时可以使用聚光灯效果来快速判断,在EXCEL中使用聚光灯需要使用条件格式来制作,这里我使用VBA来教大家制作一个聚光灯的效果,并且如果你的数据原来就有颜色标记的,聚光灯也并不会破坏它。

在开始之前,首先学习一个异或运算,异或是两个数的位运算,按位相同结果为0,不同结果为1,异或运算有一个特性,a异或b再异或b,结果还为a本身,使用异或的这个特征,可以用来恢复单元格的原颜色。

c=a xor b
d=c xor b
//此时d=a

打开VBA编辑界面,在thisworkbook对象下定义如下全局变量,用来保存当前聚光灯的行列信息,在下次改变聚光灯时方便取消之前的效果。

Public row As Long, col As Long, shn As Worksheet
Public color_row, color_col, color_pre

点击wirkbook的SelectionChange事件,自动填充Workbook_SheetSelectionChange过程。

'初始化聚光灯颜色
length = 50'填充列的长度
color_row = VBA.RGB(2177, 194, 231)
color_col = VBA.RGB(171, 243, 165)
color_row = color_row Xor vbWhite
color_col = color_col Xor vbWhite

聚光灯的行列颜色可以分别指定,这里首先将颜色与白色进行异或运算作为初始颜色,在聚光灯填充颜色时,再与单元格的原颜色进行异或,如果原色为白色,那么填充的便是最初填写的rgb颜色。

Sub setColor(ByVal rg As Range, ByVal c As Long)
    cur = rg.Interior.Color Xor c
    If cur = vbWhite Then
        rg.Interior.Pattern = xlNone
    Else
        rg.Interior.Color = cur
    End If
End Sub

设置颜色的函数,当颜色为白色时,使用pattern属性设置为xlnone,防止颜色覆盖初始的虚线网格。

'取消原聚光灯效果
If row > 0 Then
    cur = shn.Cells(row, col).Interior.Color
    If cur <> color_pre Then '还原当前手动设置的颜色
        cur = cur Xor color_row
        cur = cur Xor color_col
        shn.Cells(row, col).Interior.Color = cur
    End If
    '取消列颜色
    For i = 1 To row + lenth
        Call setColor(shn.Cells(i, col), color_row)
    Next
    '取消行颜色
    For i = 1 To 50
        Call setColor(shn.Cells(row, i), color_col)
    Next
End If

在聚光灯生效后保存聚光灯所在单元格的颜色,取消时如果颜色被改变,则先将此单元格颜色分别与聚光灯颜色异或,在之后的循环取消时又会恢复为手动设置颜色。

Set shn = Sh
'如果选中的是区域,则不设置聚光灯
If Target.CountLarge > 1 Then
    row = 0
    col = 0
    Exit Sub
End If

如果选中的单元格不是一格,则结束过程,即不需要聚光灯。

'获取当前选中的行号、列号,并保存
row = Target.row
col = Target.Column
'设置列颜色
For i = 1 To row + length
    Call setColor(shn.Cells(i, col), color_row)
Next
'设置行颜色
For i = 1 To 50
    Call setColor(shn.Cells(row, i), color_col)
Next
'保存当前选中单元格的颜色
color_pre = shn.Cells(row, col).Interior.Color

循环设置行列的颜色信息,最后将选中的单元格颜色保存,以便下次判断其是否被手动更改过。

来看看效果怎么样:

当改变I9单元格的颜色并点击其他单元格时:

以上便是使用VBA为EXCEL定制聚光灯的方法,亲爱的朋友们,你们还有什么好的方法,欢迎在评论区留言讨论。

需要源码的朋友请私信。

Tags:

最近发表
标签列表