|
本帖最后由 ning84 于 2017-3-27 06:50 编辑
学习正则表达式,已经好几年了,就是不能灵活应用。网友mzbao,用正则表达式,提取单元格的英文字母,
=(1.38*(B13+(C13+2))^2+4*(B13+(C13+2))*E13)^0.5
提取单元格的单元格(字母)后,
重新生成公式:= "(1.38×(" & B6 & "+(" & C6 & "+2))^2+4×(" & B6 & "+(" & C6 & "+2))×" & E6 & ")^0.5"
因此,再学习excelhome中的精华帖。
Excel 正则表达式入门与提高-VBA平台的正则学习参考资料-ExcelVBA程序开发-ExcelHome技术论坛 - http://club.excelhome.net/thread-1128647-1-1.html
1 正则提取字符串是不是就这两条语句。
.Pattern = "(\$*[A-Z]+\$*\d+)"
Set expRng = Reg.Execute(Str)
2 正则提取字符串,我认为能够应用的地方。
问:各位都在什么地方,使用正则。
*****************************************
网友mzbao,在这个帖子,用正则表达式,截取字符串。Excel 如何分离公式中的单元格元素?-ExcelVBA程序开发-ExcelHome技术论坛 - http://club.excelhome.net/forum. ... 7&page=1#pid9039603
*******************************************
Dim expRng, Arr, Txt
With Reg
.Global = True
.Pattern = "(\$*[A-Z]+\$*\d+)"
End With
Stop
Set expRng = Reg.Execute(Str)
现在主要理解
.Pattern = "(\$*[A-Z]+\$*\d+)"
Set expRng = Reg.Execute(Str)
********************************************
速记理解技巧编辑
.
[ ]
^
$
四个字符是所有语言都支持的正则表达式,所以这四个是基础的正则表达式。正则难理解因为里面有一个等价的概念,这个概念大大增加了理解难度,让很多初学者看起来会懵,如果把等价都恢复成原始写法,自己书写正则就超级简单了,就像说话一样去写你的正则了:
等价:
等价是等同于的意思,表示同样的功能,用不同符号来书写。
?,*,+,\d,\w 都是等价字符
?等价于匹配长度{0,1}
*等价于匹配长度{0,}
+等价于匹配长度{1,}
\d等价于[0-9]
\D等价于[^0-9]
\w等价于[A-Za-z_0-9]
\W等价于[^A-Za-z_0-9]。
常用运算符与表达式:
^ 开始
() 域段
[] 包含,默认是一个字符长度
[^] 不包含,默认是一个字符长度
{n,m} 匹配长度
. 任何单个字符(\. 字符点)
| 或
\ 转义
$ 结尾
[A-Z] 26个大写字母
[a-z] 26个小写字母
[0-9] 0至9数字
[A-Za-z0-9] 26个大写字母、26个小写字母和0至9数字
, 分割
.
分割语法:
[A,H,T,W] 包含A或H或T或W字母
[a,h,t,w] 包含a或h或t或w字母
[0,3,6,8] 包含0或3或6或8数字
语法与释义:
基础语法 "^([]{})([]{})([]{})$"
正则字符串 = "开始([包含内容]{长度})([包含内容]{长度})([包含内容]{长度})结束"
?,*,+,\d,\w 这些都是简写的,完全可以用[]和{}代替,在(?:)(?=)(?!)(?<=)(?<!)(?i)(*?)(+?)这种特殊组合情况下除外。
初学者可以忽略?,*,+,\d,\w一些简写标示符,学会了基础使用再按表自己去等价替换
实例:
字符串;tel:086-0666-88810009999
原始正则:"^tel:[0-9]{1,3}-[0][0-9]{2,3}-[0-9]{8,11}$"
速记理解:开始 "tel:普通文本"[0-9数字]{1至3位}"-普通文本"[0数字][0-9数字]{2至3位}"-普通文本"[0-9数字]{8至11位} 结束"
等价简写后正则写法:"^tel:\d{1,3}-[0]\d{2,3}-\d{8,11}$" ,简写语法不是所有语言都支持。
替换技巧编辑
实例目录
【1】 正则表达式应用——替换指定内容到行尾
【2】 正则表达式应用——数字替换
【3】 正则表达式应用——删除每一行行尾的指定字符
【4】 正则表达式应用——替换带有半角括号的多行
【5】 正则表达式应用——删除空行
【6】 正则表达式应用——实例应用
|
评分
-
1
查看全部评分
-
|