• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    excel vba 高亮显示当前行代码
    代码:
    复制代码 代码如下:

    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    ThisWorkbook.Names.Add "XM", Target
    End Sub

    这几行代码的作用是,当选择新的单元格时,将这个单元格(或者区域)定义为名称“XM”,在条件格式设置中可以引用这个名称。
    如下面的附件,将代码粘贴完成后,返回工作表中,选择A4:I15,点击菜单“格式—条件格式”,设置:
    公式1:=(A4>"")*(A4=XM)
    (如果A4不为空,并且A4等于XM)
    公式2:=ROW()=ROW(XM)
    (如果当前的行号等于XM的行号)
    用代码定义名称,我们需要它的即时更新,鼠标点到什么,这个名称“XM”就更新什么。
    例如,当鼠标点击F7单元格,XM便等于F7,ROW(XM)=7,设置条件格式的区域中,凡是Row()等于7(说白了就是第7行)的单元格便显示背景色。
    用手工定义也可得到相同的效果,可以试试。然后比较一下,用代码的好处是什么。
    当选中B6单元格时有不一样的情况出现,是因为区域中设置了两个条件格式,它符合第一个条件便显示第一种格式,符合第二个条件便显示第二个格式。
    点击菜单“格式—条件格式”可看清楚。
    初学有一个问题?能否把 高亮显示单元格 做成 自动起动的宏,让用户的鼠标单击工作表的某一个单元格后,相应的行和列都显示一种 或者 两种背景色!
    直接用VBA设置背景色,做法如下:
    鼠标右键点击工作表标签,选择“查看代码”,将下面代码粘贴到光标处:
    代码:
    复制代码 代码如下:

    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    Dim Rng As Range
    Set Rng = Target.Range("a1")
    Cells.Interior.ColorIndex = 0 '清除所有背景色
    Rng.EntireColumn.Interior.ColorIndex = 40 '设置当前列颜色
    Rng.EntireRow.Interior.ColorIndex = 36 '设置当前行颜色
    End Sub

    其中40、36为颜色索引号,不同的数值代表不同的颜色,对应索引如下:
    如果工作簿中的每张工作表都有相同效果,应该怎么做?
    按Alt+F11打开VBE编辑器,在工程管理器中双击模块“ThisWorkbook”,将下面的代码粘贴到光标处:
    代码:
    复制代码 代码如下:

    Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range)
    Dim Rng As Range
    Set Rng = Target.Range("a1")
    Cells.Interior.ColorIndex = 0 '清除所有背景色
    Rng.EntireColumn.Interior.ColorIndex = 40 '设置当前列颜色
    Rng.EntireRow.Interior.ColorIndex = 36 '设置当前行颜色
    End Sub

    使用了这个代码后,表中的“复制”和“拷贝”功能就被禁止了,不知有无办法可以解决?
    可在代码第二行(清除颜色之前就行)插入一行代码:
    If Application.CutCopyMode Then Exit Sub '如果处于选取状态则退出程序
    代码:
    复制代码 代码如下:

    Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range)
    If Application.CutCopyMode Then Exit Sub '如果处于选取状态则退出程序
    Dim Rng As Range
    Set Rng = Target.Range("a1")
    Cells.Interior.ColorIndex = 0 '清除所有背景色
    Rng.EntireColumn.Interior.ColorIndex = 40 '设置当前列颜色
    Rng.EntireRow.Interior.ColorIndex = 36 '设置当前行颜色
    End Sub
    您可能感兴趣的文章:
    • VBA中操作Excel常用方法总结
    • Excel VBA连接并操作Oracle
    • excel vba 限制工作表的滚动区域代码
    • 合并Excel工作薄中成绩表的VBA代码,非常适合教育一线的朋友
    • 用vba实现将记录集输出到Excel模板
    • Python + selenium + requests实现12306全自动抢票及验证码破解加自动点击功能
    • python requests包的request()函数中的参数-params和data的区别介绍
    • python:解析requests返回的response(json格式)说明
    • 基于python requests selenium爬取excel vba过程解析
    上一篇:excel vba 限制工作表的滚动区域代码
    下一篇:当编辑框内容改变 对应的单元格也随着改变vba代码
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    excel vba 高亮显示当前行代码 excel,vba,高亮,显示,当,前行,