正则表达式在EXCEL中使用的详细步骤

徐-清风 2024-06-06 15:36:37编程技术
391

正则表达式,相信大家都不陌生。但在我们最常用的办公软件EXCEL中,目前没有可直接使用正则表达式的函数(至少10版本的EXCEL没有),那么今天我就分享下如何在EXCEL中自定义正则函数。

一、提需求

比如,我要拆分下面的字符串:

显然这样的需求,用正则表达式再合适不过了。

二、解决步骤

下面我们使用的这个方法,定义出的函数将长期有效:

1、新建一个EXCEL文件,我这里命名为RE,随后按ALT+F11打开宏编辑器,选中任意一个sheet,右键,选择插入模块:

2、双击模块1,编辑如下VBA自定义函数代码:

Function RE(OriText As String, ReRule As String, ReplaceYesOrNo As Boolean)
'''
'OriText:待匹配的字符串
'ReRule:正则表达式
'ReplaceYesOrNo:是否采用替换方法,1表示替换,0表示不替换,默认为不替换
'''

'创建一个正则表达式实例对象
Set ReObject = CreateObject("vbscript.regexp")

With ReObject

 '是否区分大小写,一般需求是不用区分大小写,因此这里为True
 .IgnoreCase = True

 '是否匹配所有,一般需求也都是匹配所有,这里也就默认是True,如果为False表示只匹配第一次出现的
 .Global = True

 '匹配时所用到的正则表达式
 .Pattern = ReRule

 If ReplaceYesOrNo Then

  '如果使用替换方法,则将正则表达式匹配到的项替换为空
  RE = .Replace(OriText, "")

 Else
  '否则,返回可迭代对象的第一项
  RE = .Execute(OriText)(0)

 End If

End With

End Function

3、另存为加载宏格式:

4、点击下方的加载项:

5、点击浏览:

6、选择我们刚保存的加载宏格式文件,结果如下图:

好了,到这里我们的正则函数就创建好了,随后每次打开EXCEL都可以直接使用定义的RE函数,按照需求来敲出合适的正则表达式。

三、结果呈现

到此这篇关于正则表达式在EXCEL中使用的详细步骤的文章就介绍到这了,更多相关正则表达式EXCEL使用内容请搜索站长工具网以前的文章或继续浏览下面的相关文章希望大家以后多多支持站长工具网!

正则表达式 excel
THE END
ZhanShen
把烦恼扔进夕阳里,和星星一起沉沦。

相关推荐

Excel 表格中插入 PDF 文件的6种方式,你知道几个?
在Excel中嵌入PDF文件可提升数据展示的完整性和交互性,尤其适用于报告、合同、产品手册等场景。本文ZHANID工具网系统梳理6种主流插入方式,涵盖不同版本Excel(2010/2016/20...
2025-09-09 电脑知识
1060

Python实现批量加密excel文档的3种方法详解
传统EXCEL加密依赖手动操作,面对批量文件时效率低下且易出错。而Python凭借其强大的第三方库生态与自动化能力,可高效、安全的实现批量加密。本文ZHANID工具网将从基础加密原...
2025-08-26 编程技术
721

Excel表格中出现#DIV/0!是什么意思?避免#DIV/0!错误的5个实用技巧分享
在Excel数据处理中,#DIV/0!错误是用户最常遇到的公式错误之一。这个醒目的红色错误提示表示公式试图将数字除以零或空单元格,导致数学运算无法完成。本文ZHANID工具网将从错...
2025-08-18 电脑知识
755

Python正则表达式入门与实战技巧详解
正则表达式(Regular Expression)是处理字符串的强大工具,在Python中通过re模块实现。它能够帮助开发者进行字符串匹配、查找、替换和验证等操作,广泛应用于网络爬虫、数据...
2025-08-14 编程技术
486

MySQL正则表达式REGEXP查询命令使用教程
MySQL提供的REGEXP正则表达式操作符,通过模式匹配机制为字符串检索提供了灵活的解决方案。本文ZHANID工具网将系统解析REGEXP的核心语法、应用场景及性能优化策略,结合真实案...
2025-08-12 编程技术
458

Python读取Excel/CSV文件的多种方法对比
在数据处理与分析领域,Excel和CSV作为最主流的表格数据存储格式,其读取效率直接影响项目开发周期与性能表现。Python生态中已形成"标准库+第三方库+数据库中间层"的三层技术...
2025-07-31 编程技术
665