ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[分享] 对比两单元格字符不同的用颜色标注出来

[复制链接]

TA的精华主题

TA的得分主题

发表于 2017-12-13 13:32 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 大雨治水 于 2017-12-13 19:51 编辑

前些天关注了一下由简称查找全称、用于了对比字符串的相似度(或叫雷同度),并需要对不同的部分进行标注,如下图,

需要对比A列与B列的不同的字符,并标注成红色:



界面1.png


我找了许多代码,没有得到好的方案,研究了几天,做用了论坛的一个自定义函数,自己再加上几句代码,基本解决了这个问题:

界面2.png

代码不是很完善,只是达到的基本效果,大家有兴趣的可以完善一下,并分享之,谢谢!

代码如下:

  1. Sub 标注不同字符()
  2.     Dim myrow%, i%, j%, n%, m%, s%
  3.     Dim str$, s1$, s2$, s3$
  4.     Dim strA$, strB$

  5.     On Error Resume Next

  6.     Call 恢复颜色

  7.     ''将区域设置为文本格式
  8.     Columns("A:B").NumberFormatLocal = "@"

  9.     myrow = Range("A65536").End(xlUp).Row

  10.     For i = 2 To myrow
  11.         ''先修改全部字符串的颜色
  12.         Cells(i, 1).Font.Color = vbRed
  13.         Cells(i, 2).Font.Color = vbRed

  14.         strA = Cells(i, 1).Value
  15.         strB = Cells(i, 2).Value

  16.         ''提取最大相同字符串
  17.         s1 = xt(strA, strB)
  18. abc:
  19.         m = Len(s1)
  20.         n = InStr(1, Cells(i, 1).Value, s1)
  21.         ''.Characters(Start:=1, Length:=1).Font....
  22.         Cells(i, 1).Characters(n, m).Font.ColorIndex = vbBlack    '改成黑色

  23.         n = InStr(1, Cells(i, 2).Value, s1)
  24.         Cells(i, 2).Characters(n, m).Font.ColorIndex = vbBlack    '改成黑色


  25.         ''去除相同内容后,再提取相同内容
  26.         strA = Replace(strA, s1, "")
  27.         strB = Replace(strB, s1, "")
  28.         If StrReverse(strA) <> strB Then
  29.             If Len(strA) >= 2 And Len(strB) >= 2 Then
  30.                 ''提取最大相同字符串
  31.                 s1 = xt(strA, strB)
  32.                 If s1 <> "" Then
  33.                     GoTo abc
  34.                 End If
  35.             End If
  36.         End If
  37.         m = 0
  38.         n = 0

  39.     Next i

  40. End Sub
复制代码


下面这段求最大相同字符串的自定义函数是论坛找到的:

  1. Function xt(rng1, rng2)
  2. ''最大相同部分
  3.     Dim n%, j%, i%
  4.     zf = LCase(rng1)
  5.     zf2 = LCase(rng2)
  6.     p = ""
  7.     n = Len(zf)
  8.     For i = n To 1 Step -1
  9.         For j = 1 To n - i + 1
  10.             z = Mid(zf, j, i)
  11.             If InStr(zf2, z) Then
  12.                 p = z
  13.                 GoTo 100
  14.             End If
  15.         Next
  16.     Next
  17. 100:
  18.     xt = p
  19. End Function
复制代码


这个代码是调试用的,用于恢复字体颜色为黑色,可有可无:
  1. Sub 恢复颜色()
  2.     Cells.Font.ColorIndex = 0
  3. End Sub
复制代码





附件下载:

找出两个单元格中不同的字符并用颜色标示出来--谢顺胜.zip (13.65 KB, 下载次数: 343)




补充内容 (2018-8-21 15:56):
修改了一下,把最新的代码上传一下:

附件见14楼!

评分

4

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2017-12-14 09:20 | 显示全部楼层
奇怪,明明有点贴子,怎么在论坛搜索找不到!

TA的精华主题

TA的得分主题

 楼主| 发表于 2017-12-21 11:37 | 显示全部楼层
这个标题是不是有点偏僻?怎么有人下载没人回复讨论呢

TA的精华主题

TA的得分主题

 楼主| 发表于 2017-12-24 15:36 | 显示全部楼层
还是自己路过一下先!

TA的精华主题

TA的得分主题

发表于 2018-1-11 22:41 | 显示全部楼层
请问大神,用您的代码之后我要对比的数据A列和B列的内容特别多,excel一直跑圈圈,怎么解决呢?

TA的精华主题

TA的得分主题

发表于 2018-1-11 23:03 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
左右数据的字符串长度有123个,就会一直打圈圈555555555555

TA的精华主题

TA的得分主题

发表于 2018-1-12 00:19 来自手机 | 显示全部楼层
我把整形改为长整型了,还是不行啊

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-1-15 11:24 | 显示全部楼层
shyy1989 发表于 2018-1-12 00:19
我把整形改为长整型了,还是不行啊

把你的附件传上来,我测试一下看看!

TA的精华主题

TA的得分主题

发表于 2018-6-26 21:02 | 显示全部楼层
大雨治水 发表于 2017-12-24 15:36
还是自己路过一下先!

大神,代码挺好用,但是数据多一点就卡死啊,能否看一下什么原因。。

TA的精华主题

TA的得分主题

发表于 2018-7-14 09:35 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
好,谢谢提供,正需要!
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-5 05:33 , Processed in 1.171669 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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