当前位置: 首页 > news >正文

奇怪的Excel单元格字体颜色格式

使用VBA代码修改单元格全部字符字体颜色是个很简单的任务,例如设置A1单元格字体颜色为红色。

Range("A1").Font.Color = RGB(255, 0, 0)

有时需要修改部分字符的颜色,如下图所示,将红色字符字体颜色修改为蓝色。代码将会稍许复杂,需要使用Characters设置逐个字符的字体颜色。

在这里插入图片描述

先使用代码来读取单元格的字体颜色。

Sub CheckFontColor()Dim c As Range, i As LongSet c = Range("A1")For i = 1 To Len(c.Value)With c.Characters(i, 1).FontDebug.Print i, .ColorEnd WithNext
End Sub

输出如下所示,前5个字符和最后两个字符为红色。

 1             255 2             255 3             255 4             255 5             255 6             0 7             0 8             255 9             255 

略加修改,逐个字符判断字体颜色,修改红色字符为蓝色。

Sub ChangeColor1()Dim c As Range, i As Long, ColS As Long, ColE As LongRange("A1").Copy Range("A2")ColS = RGB(255, 0, 0)ColE = RGB(0, 0, 255)Set c = Range("A2")For i = 1 To Len(c.Value)With c.Characters(i, 1).FontIf .Color = ColS Then.Color = ColEEnd IfEnd WithNext
End Sub

运行代码过程ChangeColor1,结果和想象的并不相同,如下所示。前5个字符的删除线消失了,最后两个字符的颜色仍然是红色。

在这里插入图片描述

为什么会出现这个奇怪的结果呢?增加部分代码来看一下执行过程。

Sub ChangeColor2()Dim c As Range, i As Long, ColS As Long, ColE As LongRange("A1").Copy Range("A2")ColS = RGB(255, 0, 0)ColE = RGB(0, 0, 255)Set c = Range("A2")Debug.Print "before change color"Call CheckColorFor i = 1 To Len(c.Value)With c.Characters(i, 1).FontIf .Color = ColS Then.Color = ColEEnd IfEnd WithDebug.Print iCall CheckColorNext
End SubSub CheckColor()Debug.Print Range("A1").Characters(11, 1).Font.Color, Range("A2").Characters(11, 1).Font.ColorDebug.Print Range("A1").Characters(12, 1).Font.Color, Range("A2").Characters(12, 1).Font.Color
End Sub

部分输出结果如下:

before change color255           255 255           255 1 255           16711680 255           16711680 2 255           16711680 255           16711680 3 255           16711680 255           16711680 

执行For循环之前,A1和A2单元格内容完全相同,最后两个字符的颜色均为红色,然而执行循环第一次之后,也就是第一个字符修改为蓝色,此时最后两个字符的颜色被修改为了16711680(即RGB(0,0,255)),但是此时单元格中的最后两个字符仍然显示为红色,这个应该是Excel的BUG.

执行循环第一次之后,第一个字符有删除线格式,后面几个字符的删除线已经消失,执行第二次循环之后,第二字符字体颜色被修改为蓝色,但是第一个字符的删除线格式消失了。由于最后两个字符的Font.Color的返回值不再是255,因此后续代码不会更新那两个字符的字体颜色,最终仍然为红色字符。

在这里插入图片描述

VBA处理这种复合字体格式(单元格中的字符具备多种不同的字体格式)会出现这种诡异的现象,但是也是有变通方法可以实现这个需求的。

Type FontStyleColor As LongStrikethrough As Boolean
End Type
Sub ChangeColor3()Dim c As Range, i As Long, ColS As Long, ColE As LongDim CellFont() As FontStyleColS = RGB(255, 0, 0)ColE = RGB(0, 0, 255)Range("A1").Copy Range("A2")Set c = Range("A2")ReDim CellFont(1 To Len(c.Value))For i = 1 To Len(c.Value)With c.Characters(i, 1).FontCellFont(i).Color = .ColorCellFont(i).Strikethrough = .StrikethroughEnd WithNextFor i = 1 To Len(c.Value)With c.Characters(i, 1).FontIf CellFont(i).Color = ColS Then.Color = ColEElse.Color = CellFont(i).ColorEnd If.Strikethrough = CellFont(i).StrikethroughEnd WithNext
End Sub

【代码解析】
第1~4行代码声明自定义数据结构。
第13~18行代码将每个字符的字体属性保存在数组CellFont中。
第19~28行代码循环遍历每个字符。
第21行代码判断字符颜色,如果颜色匹配,第22行代码更新字符的字体颜色,否则第24行代码恢复字符的原字体颜色。
此处使用CellFont(i).Color,避免更新字符字体格式对于其他字符格式的影响。
第26行代码恢复字符的删除线格式。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 获取后端返回的图形验证码
  • 线上语音交友平台成熟案例源码出售本地找搭子交友app软件线下陪玩系统开发服务
  • WebStorm中在Terminal终端运行脚本时报错无法加载文件进行数字签名。无法在当前系统上运行该脚本。有关运行脚本和设置执行策略的详细信息,请参阅
  • el-image预览图片点击遮盖处关闭预览
  • C++版OpenCV_03_图像增强
  • 筑牢数字防线:从微软蓝屏事件看网络安全与系统韧性建设
  • linux自动化构建工具--make/makefile
  • 学生成绩管理系统(C语言)
  • 关于使用宝兰德bes中间件进行windows部署遇到的问题——license不存在
  • Git仓库拆分和Merge
  • 计算机网络基础:4.HTTP与HTTPS
  • 打造智慧图书馆:AI视频技术助力图书馆安全与秩序管理
  • 02集成开发工具配置VScode SSH连接Ubuntu20.04 - 输入密码连接
  • 【LeetCode:2766. 重新放置石块 + 哈希表】
  • 构建智慧水利系统,优化水资源管理:结合物联网、云计算等先进技术,打造全方位、高效的水利管理系统,实现水资源的最大化利用
  • hexo+github搭建个人博客
  • 时间复杂度分析经典问题——最大子序列和
  • 「前端」从UglifyJSPlugin强制开启css压缩探究webpack插件运行机制
  • Angular 2 DI - IoC DI - 1
  • avalon2.2的VM生成过程
  • C++回声服务器_9-epoll边缘触发模式版本服务器
  • CentOS7简单部署NFS
  • es6(二):字符串的扩展
  • ESLint简单操作
  • HTTP那些事
  • Java 9 被无情抛弃,Java 8 直接升级到 Java 10!!
  • Java小白进阶笔记(3)-初级面向对象
  • Meteor的表单提交:Form
  • PermissionScope Swift4 兼容问题
  • 百度地图API标注+时间轴组件
  • 电商搜索引擎的架构设计和性能优化
  • 前端性能优化——回流与重绘
  • 前端性能优化--懒加载和预加载
  • 视频flv转mp4最快的几种方法(就是不用格式工厂)
  • 算法之不定期更新(一)(2018-04-12)
  • 通过几道题目学习二叉搜索树
  • 摩拜创始人胡玮炜也彻底离开了,共享单车行业还有未来吗? ...
  • ​ssh免密码登录设置及问题总结
  • ​你们这样子,耽误我的工作进度怎么办?
  • (+4)2.2UML建模图
  • (1/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (11)工业界推荐系统-小红书推荐场景及内部实践【粗排三塔模型】
  • (BFS)hdoj2377-Bus Pass
  • (附源码)ssm高校社团管理系统 毕业设计 234162
  • (三)Honghu Cloud云架构一定时调度平台
  • (三)uboot源码分析
  • (十七)Flink 容错机制
  • (提供数据集下载)基于大语言模型LangChain与ChatGLM3-6B本地知识库调优:数据集优化、参数调整、Prompt提示词优化实战
  • (五)activiti-modeler 编辑器初步优化
  • (转)JVM内存分配 -Xms128m -Xmx512m -XX:PermSize=128m -XX:MaxPermSize=512m
  • .NET CF命令行调试器MDbg入门(一)
  • .NET MVC第三章、三种传值方式
  • .NET 使用 ILMerge 合并多个程序集,避免引入额外的依赖
  • .NET/C# 如何获取当前进程的 CPU 和内存占用?如何获取全局 CPU 和内存占用?
  • .net经典笔试题