ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[讨论] VBA版太沉闷了 出个小题考考大家 正则取不重复

[复制链接]

TA的精华主题

TA的得分主题

发表于 2015-10-21 12:21 | 显示全部楼层 |阅读模式
这两天VBA版太沉闷了,出个小题给大家玩玩:
题目:
有一字符串:s = "今天是2015年10月21日,农历9月初9,是老人节。"   ,从中取出包含的数字,重复的取一个。
模拟结果:50219
要求只准用正则。

TA的精华主题

TA的得分主题

发表于 2015-10-21 14:32 | 显示全部楼层
  1. Dim reg, s
  2. s = "今天是2015年10月21日,农历9月初9,是老人节。Excel 2003/07/10/13技术交流与问答 ? ExcelVBA程序开发 ? VBA版太沉闷了 出个小题考考大家 正则取不重有事找我,请用邮箱联系(513723192@qq.com),不加好友"
  3. Set reg = CreateObject("vbscript.regexp")
  4. reg.Pattern = "\D"
  5. reg.Global = True
  6. s = reg.Replace(s, "")
  7. reg.Pattern = "(?=(\d)(.*?)\1)\d"
  8. s = reg.Replace(s, "")

  9. MsgBox s
复制代码

评分

4

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-10-21 19:40 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2015-10-21 19:59 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2015-10-21 20:06 | 显示全部楼层
  1. Dim reg, s

  2. s = "今天是2015年10月21日,农历9月初9,是老人节。Excel 2003/07/10/13技术交流与问答 ? ExcelVBA程序开发 ? VBA版太沉闷了 出个小题考考大家 正则取不重有事找我,请用邮箱联系(513723192@qq.com),不加好友"

  3. Set reg = CreateObject("vbscript.regexp")

  4. reg.Global = True

  5. reg.Pattern = "(?:(?=(\d)(.*?)\1)\d)|\D"

  6. s = reg.Replace(s, "")

  7. MsgBox s
复制代码


评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-10-21 20:50 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助

学习了,麻烦解释一下正则表达式的意思。

TA的精华主题

TA的得分主题

发表于 2015-10-21 21:20 | 显示全部楼层
我是这么想的,要得到答案,我可以先把非数字给替换掉,非数字即\D,
另外我再把那些数字中重复的数字替换掉就行了。
(?=(\d)(.*?)\1)\d          这个正则匹配的值为一个数字,而这个数字必须满足的条件就是其为重复的数字  。例如匹配121,11,但是不匹配单个的数字1
然后我把前面一个字符给替换掉,就是前面例子中的121替换为21,11替换为1,从而达到保留一个数字的目的
(?:(?=(\d).*?\1)\d)|\D+,上面的还可以稍作修改

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-10-21 21:57 | 显示全部楼层
袁振涛 发表于 2015-10-21 21:20
我是这么想的,要得到答案,我可以先把非数字给替换掉,非数字即\D,
另外我再把那些数字中重复的数字替换 ...

佩服,你要么是正则高手,要么很聪明,或者二者皆是。
我在理解Pattern = "(?:(?=(\d)(.*?)\1)\d)|\D" 的时候 ?: 对我造成了干扰,去掉 ?: 以后就比较容易理解了,谢谢你。

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-10-22 10:09 | 显示全部楼层
袁振涛 发表于 2015-10-21 21:20
我是这么想的,要得到答案,我可以先把非数字给替换掉,非数字即\D,
另外我再把那些数字中重复的数字替换 ...

试试按出现的先后顺序提取,结果是:20159
只用正则。

TA的精华主题

TA的得分主题

发表于 2015-10-22 10:15 | 显示全部楼层
小花鹿 发表于 2015-10-22 10:09
试试按出现的先后顺序提取,结果是:20159
只用正则。

提取并不难,题目应该改成,用正则标颜色
答案如下
"今天是2015年10月21日,农历9月初9,是老人节。"
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

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

GMT+8, 2024-4-24 09:35 , Processed in 0.050861 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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