ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 612|回复: 0

[原创] 检查选区内公式是不是一样的

[复制链接]

TA的精华主题

TA的得分主题

发表于 2020-5-6 16:42 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
有时候在接手别人的EXCEL模版时,面对密密麻麻的公式,是不是有点头大,从哪里看起即使切换R1C1模式,也会瞅得眼花,Office内置的公式审核中,没有相关相邻单元格区域公式比对的功能,这里用宏做了个公式检查小助手。
代码如下:
Sub 检查公式是否相同()
Dim myArr
Dim tiped As Boolean
Application.StatusBar = ""
'On Error Resume Next
Call ChangeIntoR1C1mode
xx = Selection.Rows.Count
yy = Selection.Columns.Count
ReDim myArr(1 To xx, 1 To yy)
myJ = True
tiped = False
mJ = True

For Each ce In Selection
   If ce.HasFormula = False Then mJ = False: MsgBox "选择的区域中【cells(" & ce.Row & "," & ce.Column & ")没有公式!检查将退出!": Application.StatusBar = "选择的区域中【cells(" & ce.Row & "," & ce.Column & ")没有公式!检查将退出!": Exit Sub
Next ce


For i = 1 To xx
    For j = 1 To yy

         myFormulaStr = Selection(i, j).FormulaR1C1  'R1C1样式的公式内的文本
         If Selection(i, j).HasArray Then myFormulaStr = "{" & myFormulaStr & "}"   '如果是数组公式,则添加"{"  "}"
         myArr(i, j) = myFormulaStr
         myStr0 = myArr(1, 1)
         myStr1 = myArr(i, j)
        If myStr0 <> myStr1 Then myJ = False
    Next j
Next i

If xx > 1 And yy > 1 Then

   If myArr(1, 1) <> myArr(1, 2) And myArr(1, 1) <> myArr(2, 1) Then
       myTip = MsgBox("行列中x轴和y轴方向公式都不一样!", vbExclamation, "警告!"): Application.StatusBar = "行列中x轴和y轴方向公式都不一样!": tiped = True
   ElseIf tiped = False And myArr(1, 1) <> myArr(1, yy) And myArr(1, 1) <> myArr(xx, 1) Then
       myTip = MsgBox("行列中x轴和y轴方向公式都不一样!", vbExclamation, "警告!"): Application.StatusBar = "行列中x轴和y轴方向公式都不一样!": tiped = True

   ElseIf tiped = False And myArr(1, 1) <> myArr(1, 2) Then myTip = MsgBox("同一行中x轴方向公式不一样!", vbExclamation, "警告!"): Application.StatusBar = "同一行中x轴方向公式不一样!": tiped = True
   ElseIf tiped = False And myArr(1, 1) <> myArr(2, 1) Then myTip = MsgBox("同一列中y轴方向公式不一样!", vbExclamation, "警告!"): Application.StatusBar = "同一列中y轴方向公式不一样!": tiped = True
   ElseIf tiped = False And myArr(1, 1) <> myArr(1, yy) Then myTip = MsgBox("同一行中x轴方向公式不一样!", vbExclamation, "警告!"): Application.StatusBar = "同一行中x轴方向公式不一样!": tiped = True
   ElseIf tiped = False And myArr(1, 1) <> myArr(xx, 1) Then myTip = MsgBox("同一列中y轴方向公式不一样!", vbExclamation, "警告!"): Application.StatusBar = "同一列中y轴方向公式不一样!": tiped = True
   Else
   End If
Else

    If yy > 1 Then
          If tiped = False And myArr(1, 1) <> myArr(1, 2) Then
             myTip = MsgBox("同一行中x轴方向公式不一样!", vbExclamation, "警告!"): Application.StatusBar = "同一行中x轴方向公式不一样!": tiped = True
          ElseIf tiped = False And myArr(1, 1) <> myArr(1, yy) Then
             myTip = MsgBox("同一行中x轴方向公式不一样!", vbExclamation, "警告!"): Application.StatusBar = "同一行中x轴方向公式不一样!": tiped = True
          Else
          End If
    End If

     If xx > 1 Then
         If tiped = False And myArr(1, 1) <> myArr(2, 1) Then
             myTip = MsgBox("同一列中y轴方向公式不一样!", vbExclamation, "警告!"): Application.StatusBar = "同一列中y轴方向公式不一样!": tiped = True
         ElseIf tiped = False And myArr(1, 1) <> myArr(xx, 1) Then
             myTip = MsgBox("同一列中y轴方向公式不一样!", vbExclamation, "警告!"): Application.StatusBar = "同一列中y轴方向公式不一样!": tiped = True
         Else
         End If
     End If
End If
If myJ = True Then
  MsgBox "选区公式一致!": Application.StatusBar = "选区公式一致!": tiped = True
Else
     If tiped = False Then myTip = MsgBox("选区公式不一致!请按行及按列检查!", vbExclamation, "警告!"): Application.StatusBar = "选区公式不一致!请按行及按列检查!"
End If
Call ChangeIntoA1mode
End Sub

Sub ChangeIntoR1C1mode()
Application.ReferenceStyle = xlR1C1 'xlR1C1

End Sub


Sub ChangeIntoA1mode()
Application.ReferenceStyle = xlA1

End Sub

使用方法:
把上面的代码复制到模块中就可以使用了。
选中要比对的单元格区域(注意是相邻区域,不支持非相邻区域,要达到非相邻区域的功能自己去修改代码哦),运行宏“检查公式是否相同”


您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-5-10 10:07 , Processed in 0.034037 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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