ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 查找含有某个字根的字

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-2-23 22:38 | 显示全部楼层 |阅读模式
如附件所示

sheet1列出了汉字常用字的字根。现在在sheet2中的A列有一些词语,如果我在F2黄色单元格输入一个字根符号,希望在F2下面把 A列里面所有含这个字根的词语 都列出来。是否含有这个字根以sheet1字根表为准。
sheet2的A列可能有几百个词语。请问高手,是否可以通过vma实现这个功能?
感谢!!

字根.zip

106.08 KB, 下载次数: 14

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-23 22:40 | 显示全部楼层
是希望通过VBA excel宏来实现,上面写错了。

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-23 22:54 来自手机 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
还有,sheet2中的A列不一定是二字词,有可能是三四个四五个字的词,这个词里任何一个字含有这个字根就要列出来。

TA的精华主题

TA的得分主题

发表于 2024-2-23 23:32 | 显示全部楼层
去掉前面表1单词和字根的空格键后,代码如下:
image.jpg

TA的精华主题

TA的得分主题

发表于 2024-2-23 23:40 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2024-2-24 01:12 | 显示全部楼层
忙乎半天 才发现 VBA内这些字符识别不出来
代码是按照一般字符做的,可以参考一下
字根.rar (124.71 KB, 下载次数: 0)
  1. Sub OPI()
  2.    
  3.     Set SHX = Worksheets("Sheet2")
  4.     SHX.AutoFilterMode = False  '//取消筛选
  5.     MAXROW = SHX.Range("a" & SHX.Rows.Count).End(3).Row
  6.     ARX = SHX.Range("A2:" & SHX.Cells(MAXROW, "A").Address).Value
  7.    
  8.     Set SHD = Worksheets("Sheet1")
  9.     SHD.AutoFilterMode = False  '//取消筛选
  10.     MAXROW = SHD.Range("a" & SHD.Rows.Count).End(3).Row
  11. '    DRX = SHD.Range("A3:" & SHD.Cells(MAXROW, "C").Address).Value
  12.     Set ZDD = CreateObject("Scripting.Dictionary")
  13. '       For I = 1 To UBound(DRX, 1)
  14. '        If InStr(DRX(I, 3), SHX.Range("F2").Value) > 0 Then
  15. '            ZDD(DRX(I, 2)) = DRX(I, 1)
  16. '        End If
  17. '    Next
  18.     For I = 3 To MAXROW
  19.         If InStr(SHD.Cells(I, "C").Value, SHX.Range("F2").Value) > 0 Then
  20.             ZDD(SHD.Cells(I, "B").Value) = SHD.Cells(I, "C").Value
  21.         End If
  22.     Next
  23.    
  24.     Set ZAD = CreateObject("Scripting.Dictionary")
  25.     For I = 1 To UBound(ARX, 1)
  26.         For X = 1 To Len(ARX(I, 1))
  27.             StrX = Mid(ARX(I, 1), X, 1)
  28.             If ZDD.exists(StrX) = True Then
  29.                 ZAD(ARX(I, 1)) = StrX
  30.                 Exit For
  31.             End If
  32.         Next
  33.     Next
  34.    
  35.     ERX = ZAD.KEYS
  36.     SHX.Range("F3:F" & SHX.Rows.Count).ClearContents
  37.     For X = 0 To UBound(ERX)
  38.         SHX.Cells(X + 3, "F").Value = ERX(X)
  39.     Next
  40.    
  41. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2024-2-24 07:59 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
写到一半放弃了,原来发现根据字根查到的汉字并不是原来的汉字了。这个编码如何转换为汉字,目前不清楚。

TA的精华主题

TA的得分主题

发表于 2024-2-24 08:12 | 显示全部楼层
本帖最后由 shiruiqiang 于 2024-2-24 08:39 编辑
ykcbf1100 发表于 2024-2-24 07:59
写到一半放弃了,原来发现根据字根查到的汉字并不是原来的汉字了。这个编码如何转换为汉字,目前不清楚。

把字根做字典
引用了ykcbf1100老师的代码,去处b\c列的空格
image.jpg

字根.rar

130.13 KB, 下载次数: 6

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-2-24 08:16 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-24 08:34 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
感谢shiruiqiang老师提供的帮助,也感谢ykcbf1100老师的辛苦!!
问题已解决,编写的宏程序很好用!深表感谢!!
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-9-30 04:33 , Processed in 0.037795 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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