ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

EH搜索     
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
一招顶“一万招”的懒人技巧 Excel 2016函数公式学习大典 Office知识技巧免费学 打造核心竞争力的职场宝典
300集Office 2010微视频教程 Tableau-数据可视化工具 精品推荐-800套精选PPT模板,点击获取 ExcelHome出品 - VBA代码宝免费下载
你的Excel 2010实战技巧学习锦囊 欲罢不能, 过目难忘的 Office 新界面 Excel VBA经典代码实践指南
查看: 138|回复: 21

[求助] 单元格字体着色代码错误,请大家帮助

[复制链接]

TA的精华主题

TA的得分主题

发表于 2021-1-13 22:01 | 显示全部楼层 |阅读模式
本帖最后由 wangjwpx 于 2021-1-14 08:14 编辑
  1. Sub 对应单元格着色2_Click()



  2. For i = 6 To 56
  3. For k = 4 To 8

  4. For j = 15 To 19



  5.           If Cells(i, k) = Cells(4, j) Then                   '如果有数字相同,那么
  6.          
  7.                Cells(i, k).Font.Color = vbRed          '着色红色
  8.                
  9.             Else                                     '否则
  10.                  
  11.                   Cells(i, k).Font.Color = RGB(112, 48, 160)        '数字不相同着色蓝色
  12.                   
  13.           End If
  14.        Next
  15.   Next

  16. Next



  17. End Sub
复制代码
加上Else,Cells(i, k).只有一个单元格变成红色。代码1可以有数字相同着色,代码2只有一个单元格着色。具体见附件,代码1正常,代码2为什么只有一个单元格35着色?

2个区域单元格着色.rar

36.74 KB, 下载次数: 2

TA的精华主题

TA的得分主题

发表于 2021-1-13 23:06 来自手机 | 显示全部楼层
   你的代码等同于这个,不知道你的目的,也没有附件
Sub 对应单元格着色2_Click()



    For i = 6 To 56
    For k = 4 To 8
     
        If Cells(i, k) = Cells(4, 19) Then                   '如果有数字相同,那么
              
               Cells(i, k).Font.Color = vbRed          '着色红色
                  
        Else                                     '否则
                     
                  Cells(i, k).Font.Color = RGB(112, 48, 160)        '数字不相同着色蓝色
                     
              End If
           Next
      Next
     
    Next



    End Sub

评分

参与人数 1鲜花 +1 收起 理由
wangjwpx + 1 感谢帮助

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-1-14 08:09 | 显示全部楼层
此乃小白一枚 发表于 2021-1-13 23:06
你的代码等同于这个,不知道你的目的,也没有附件
Sub 对应单元格着色2_Click()

谢谢回复,附件已上传。主要问题是代码2


加上Else,Cells(i, k).只有一个单元格变成红色。

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-1-14 08:20 | 显示全部楼层
主要问题是代码2加上Else,Cells(i, k).只有一个单元格变成红色。

TA的精华主题

TA的得分主题

发表于 2021-1-14 09:21 | 显示全部楼层
F8逐步运行不就知道了
Sub 对应单元格着色2_Click()
    For i = 6 To 56
        For k = 4 To 8
            For j = 15 To 19
                If Cells(i, k) = Cells(4, j) Then                   '如果有数字相同,那么
                    Cells(i, k).Font.Color = vbRed          '着色红色
                    Exit For'匹配到了退出循环
                Else                                     '否则
                    Cells(i, k).Font.Color = RGB(112, 48, 160)        '数字不相同着色蓝色
                End If
            Next
        Next
    Next
End Sub

评分

参与人数 1鲜花 +2 收起 理由
wangjwpx + 2 感谢帮助

查看全部评分

TA的精华主题

TA的得分主题

发表于 2021-1-14 10:09 | 显示全部楼层
Sub 对应单元格着色2_Click()
For i = 6 To 56
     For k = 4 To 8
          For j = 15 To 19
          Debug.Print i, k, j
               If Cells(i, k) = Cells(4, j) Then                   '如果有数字相同,那么
                    Cells(i, k).Font.Color = vbRed
                    Exit For
               Else
                    Cells(i, k).Font.Color = RGB(112, 48, 160)        '数字不相同着色蓝色
               End If
          Next
     Next
Next
End Sub

评分

参与人数 1鲜花 +2 收起 理由
wangjwpx + 2 感谢帮助

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-1-14 10:49 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-1-14 11:02 | 显示全部楼层
XUEJUNXI 发表于 2021-1-14 10:09
Sub 对应单元格着色2_Click()
For i = 6 To 56
     For k = 4 To 8

Debug.Print i, k, j什么意思?

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-1-14 11:04 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2021-1-14 11:04 | 显示全部楼层
wangjwpx 发表于 2021-1-14 11:02
Debug.Print i, k, j什么意思?

这是运行时,我从立即窗口看的,忘了删掉了
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关注官方微信,高效办公专列,每天发车

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2021-1-24 23:23 , Processed in 0.096158 second(s), 22 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2021 Wooffice Inc.

   

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:徐怀玉律师 李志群律师

快速回复 返回顶部 返回列表