excel中用正则匹配_excel使用正则表达式

excel文件格式:

需求:用正则表达式提取D列的***,写到E列中

步骤:

1.打开excel中的vb编辑器,点击“文件”--“选项”--“自定义功能区”,勾选“开发工具”

2.点击确定后,按Ctrl+F11打开vb窗口,点击查看代码,打开代码窗口

3.在代码窗口中输入代码Sub testRegexp()

Dim a, b, c

Dim regexp As Object

Dim d As String

Set regexp = CreateObject("vbscript.regexp")

With regexp

.Global = True

.IgnoreCase = True

.Pattern = ".* .{2} \d{8} (\d{18}|\d{17}[xX])"

End With

For Each a In Range("D2:D4")

Set b = regexp.Execute(a.Value)

Rem b.Count大于0就是匹配成功

If b.Count > 0 Then

For Each c In b

Rem SubMatches.Count大于0就是捕获成功

If c.SubMatches.Count > 0 Then

Rem vbCrLf是单元格内换行符

d = d + c.SubMatches(0) + vbCrLf

End If

Next c

End If

Worksheets("Sheet1").Cells(a.Row, a.Column + 1).Value = d

d = ""

Next a

End Sub

4.按F5运行代码

5.运行效果

参考文档:

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值