ExcelVBA实现单元格背景颜色与RGB值互转
创作时间:
作者:
@小白创作中心
ExcelVBA实现单元格背景颜色与RGB值互转
引用
CSDN
1.
https://blog.csdn.net/fsyuheduo/article/details/144522284
在Excel中,我们通常用手工操作,设置单元格的背景颜色。而在电脑编程中,单元格的背景颜色由RGB(Red - 红、Green - 绿、Blue - 蓝)颜色模型是一种通过混合不同比例的红、绿、蓝三种颜色分量来表示颜色的方式。每个颜色分量的值范围是0到255。例如,(255, 0, 0)表示纯红色,(0, 255, 0)表示纯绿色,(0, 0, 255)表示纯蓝色,而(0, 0, 0)表示黑色,(255, 255, 255)表示白色。
颜色分量的意义
- 红色分量(Red):决定了颜色中红色的强度。当红色分量的值越高时,颜色就越偏向红色。
- 绿色分量(Green):控制颜色中绿色的含量。较高的绿色分量值使颜色更倾向于绿色。
- 蓝色分量(Blue):确定颜色中蓝色的比重。大的蓝色分量值会让颜色更接近蓝色。
通过调整这三个分量的不同组合,可以创建出各种各样的颜色。
手工操作:设置单元格背景颜色并查看RGB值
鼠标右键已填充颜色的单元格->>点击打开“设置单元格格式”->>点击“填充”选项下的“其他颜色”->>点击“自定义”,选择颜色模式为RGB->>
下面进行ExcelVBA编程设计,我先设计了这样子的一个测试场景
在工作表“ 色彩”中,两个区域,
- 由RGB取色:从K25单元格开始
- 由色取RGB:从E25单元格开始
在VBA中:由RGB值设置单元格背景颜色
示例代码
Sub 由RGB取色()
Dim Rng As Range
With Worksheets("色彩")
lastRow = .Range("K25").End(xlDown).Row
For i = 26 To lastRow
Set Rng = .Range("k" & i)
rN = CInt(Rng.Offset(0, 1).value)
Gn = CInt(Rng.Offset(0, 2).value)
Bn = CInt(Rng.Offset(0, 3).value)
Rng.Offset(0, 4).Interior.Color = RGB(rN, Gn, Bn)
Next
End With
End Sub
代码解析:
- 从K25到K25最后的一行循环
- RN=L列的值,GN=M列的值,BN=M列的值
- Range.Interior.Color=RGB(RN,GN,BN)的值
在VBA中:由单元格背景颜色提取RGB值
示例代码
Sub 由色取RGB()
Dim Rng As Range
With Worksheets("色彩")
lastRow = .Range("E25").End(xlDown).Row
For i = 26 To lastRow
Set Rng = .Range("F" & i)
Rng.Offset(0, 1) = Rng.Interior.Color Mod 256
Rng.Offset(0, 2) = Rng.Interior.Color \ 256 Mod 256
Rng.Offset(0, 3) = Rng.Interior.Color \ 256 \ 256 Mod 256
Next
End With
End Sub
代码解析:
相关知识
Mod运算
Mod运算符用于计算两个数相除后的余数,即取模运算
如:result =10 Mod 3 ' result 的值为 1\运算
\运算符用于执行整除运算,即计算两个数相除后的整数部分
如:result = 10 \ 3 ' result 的值为 3从E25到E25最后的一行循环
Rng.Interior.Color是一个Long型整数
R=Long Mod 256,就是 Long除以256后的余数,G,B同理进行取整再取余的运算。
下面是效果图
总结
单元格背景颜色与RGB值互转
热门推荐
腓骨远端骨折愈合周期是多少
银行贷款额度的影响因素有哪些?
2025年高考等级赋分怎么算?最新全国各省赋分规则汇总
2025新高考必看!一文弄懂赋分制度,想赋90+要考多少分?
餐后血糖多少为正常
王树国校长:今年福耀科技大学就要招生了 建校对标斯坦福大学
压疮如何预防
植物人如何承担赡养义务:法律与伦理问题探讨
脑机接口让“读懂大脑”成为可能
物业公摊电费,老张告赢!——文昌法院审结一起物业服务合同纠纷
发烧伴有腹痛要警惕
张剑:网络攻防技术对抗之网络安全防御之挂图作战
为什么我们有不同的肤色?
FPGA实现Canny算法(Verilog)
解锁竹艺的N种新玩法,“玩竹博物馆”亮相百丈溪口村
劳动法保护员工权益:辞退员工需遵循相关法律法规
结婚对健康有诸多好处
钓鱼提竿技巧,钓鱼提竿技巧大全
在山野间治愈自己 拉萨掀起“徒步热”
神经外科主要看哪些方面的疾病症状
打新股资金要冻结多久?打新股的规则(2025最新版,建议收藏)
英伟达 CEO 黄仁勋预言:未来,每个人都将拥有自己的 AI 导师
深圳宝安一小区预收"公摊电费"引争议 街道:严禁擅自设立收费项目
持久层框架JPA与Mybatis该如何选型
JT&N观点 | 分布式光伏项目的补贴政策
寒假中,大学生如何培养或加强自己的自律性?
况怨无小大,生于所爱;物无美恶,过则为灾。
月季埋鱼肠的原理及注意事项(附效果展示)
安居水站:奥威尔《1984》我们如何警惕!
Jordan标准型