15年来,为全国50万+企业提供互联网数字化基础应用服务。
微网小程序
电商运营
关于我们
付款方式
荣誉资质
业务提交
代理合作
知 识
400-1100-266
9:00-24:00(工作日)
首 页
企业400电话
Hot
网站建设
商标✡知产
网络优化推广
热
AI电话机器人
呼叫中心
彩铃•短信
增值拓展业务
新
主页
>
知识库
> Further Study of Rugular Expresions第1/2页
Further Study of Rugular Expresions第1/2页
热门标签:
银行业务
科大讯飞语音识别系统
团购网站
服务器配置
Linux服务器
电子围栏
Mysql连接数设置
阿里云
小弟便兴起了学一学re的想法,但小弟天生就比较懒一些,总希望看有没有些快速学习的方式,于是小弟又请出google大神,藉由祂的神 力,小弟在网络上找到了jim hollenhorst先生的文章,经过了阅读,小弟觉得真是不错,所以就做个小心得报告,跟move-to.net的朋 友分享,希望能为各位大大带来一丁点在学习re时的帮助。jim hollenhorst大大文章之网址如下,有需要的大大可直接连结。
the 30 minute regex tutorial by jim hollenhorst
http://www.codeproject.com/useritems/regextutorial.asp
什么是re?
想必各位大大在做文件查找的时侯都有使用过万用字符”*”,比如说想查找在windows目录下所有的word文件时,你可能就会用”*.doc”这样的方式来做查找,因为”*”所代表的是任意的字符。re所做的就是类似这样的功能,但其功能更为强大。
写程序时,常需要比对字符串是否符合特定样式,re最主要的功能就是来描述这特定的样式,因此可以将re视为特定样式的描述式,举个例子来说,”\ w +”所代表的就是任何字母与数字所组成的非空字符串(non-null string)。在.net framework中提供了非常强大的类别库, 藉此可以很轻易的使用re来做文字的查找与取代、对复杂标头的译码及验证文字等工作。
学习re最好的方式就是藉由例子亲自来做做看。jim hollenhorst大大也提供了一个工具程序expresso(来杯咖啡吧),来帮助我们学习re,下载的网址是http://www.codeproject.com/useritems/regextutorial/expressosetup2_1c.zip。
接下来,就让我们来体验一些例子吧。
一些简单的例子
假设要查找文章中elvis后接有alive的文字符串的话,使用re可能会经过下列的过程,括号是所下re的意思:
1. elvis (查找elvis)
上述代表所要查找的字符顺序为elvis。在.net中可以设定乎略字符的大小写,所以”elvis”、”elvis”或者是”elvis”都是符合 1 所下的re。但因为这只管字符出现的顺序为elvis,所以pelvis也是符合1所下的re。可以用2的re来改进。
2. \belvis\b (将elvis视为一整体的字查找,如elvis、elvis乎略字符大小写时)
“\b”在re中有特别的意思,在上述的例子中所指的就是字的边界,所以\belvis\b用\b把elvis的前后边界界定出来,也就是要elvis这个字。
假设要将同一行里elvis后接有alive的文字符串找出来,此时就会用到另外二个特别意义的字符”.”及”*”。”.”所代表就是除了换行字符的 任意字符,而”*”所代表的是重复*之前项目直到找到符合re的字符串。所以”.*”所指的就是除了换行字符外的任意数目的字符数。所以查找同一行里 elvis后接有alive的文字符串找出来,则可下如3之re。
3. \belvis\b.*\balive\b (查找elvis后面接有alive的文字符串,如elvis is alive)
用简单之特别字符就可以组成功能强大的re,但也发现当使用越来越多的特别字符时,re就会越来越难看得懂了。
再看看另外的例子
组成有效的电话号码
假使要从网页上收集顾客格式为xxx-xxxx的7位数字的电话号码,其中x是数字,re可能会这样写。
4. \b\d\d\d-\d\d\d\d (查找七位数字之电话号码,如123-1234)
每一个\d代表一个数字。”-”则是一般的连字符号,为避免太多重复的\d,re可以改写成如5的方式。
5. \b\d{3}-\d{4} (查找七位数字电话号码较好的方法,如123-1234)
在\d后的{3},代表重复前一个项目三次,也就是相等于\d\d\d。
re的学习及测试工具 expresso
因为re不易阅读及使用者容易会下错re的特性,jim大大开发了一个工具软件expresso,用来帮助使用者学习及测试re,除了上面所述的网址之外,也可以上ultrapico网站(http://www.ultrapico.com)。安装完expresso后,在expression library中,jim大大把文章的例子都建立在其中,可以边看文章边测试,也可以试着修改范例所下的re,马上可以看到结果,小弟觉得非常好用。各位大大可以试试。
.net中re的基础概念
特殊字符
有些字符有特别的意义,比如之前所看到的”\b”、”.”、”*”、”\d”等。”\s”所代表的是任意空格符,比如说spaces、tabs、newlines等.。”\w”代表是任意字母或数字字符。
再看一些例子吧
6. \ba\w*\b (查找a开头的字,如able)
这re描述要查找一个字的开始边界(\b),再来是字母”a”,再加任意数目的字母数字(\w*),再接结束这个字的结束边界(\b)。
7. \d+ (查找数字字符串)
“+”和”*”非常相似,除了+至少要重复前面的项目一次。也就是说至少有一个数字。
8. \b\w{6}\b (查找六个字母数字的字,如ab123c)
下表为re常用的特殊字符
. 除了换行字符的任意字符
\w 任意字母数字字符
\s 任意空格符
\d 任意数字字符
\b 界定字的边界
^ 文章的开头,如”^the'' 用以表示出现于文章开头的字符串为”the”
$ 文章的结尾,如”end$”用以表示出现在文章的结尾为”end”
特殊字符”^”及”$”是用来查找某些字必需是文章的开头或结尾,这在验证输入是否符合某一样式时特别用有,比如说要验证七位数字的电话号码,可能会输入如下9的re。
9. ^\d{3}-\d{4}$ (验证七位数字之电话号码)
这和第5个re相同,但其前后都无其它的字符,也就是整串字符串只有这七个数字的电话号码。在.net中如果设定multiline这个选项,则”^”和”$”会每行进行比较,只要某行的开头结尾符合re即可,而不是整个文章字符串做一次比较。
转意字符(escaped characters)
有时可能会需要”^”、”$”单纯的字面意义(literal meaning)而不要将它们当成特殊字符,此时”\”字符就是用来移除特殊字符特别意义的字符,因此”\^”、”\.”、”\\”所代表的就是”^”、”.”、”\”的字面意义。
重复前述项目
在前面看过”{3}”及”*”可以用来重复前述字符,之后我们会看到如何用同样的语法重复整个次描述(subexpressions)。下表是使用重复前述项目的一些方式。
* 重复任意次数
+ 重复至少一次
? 重复零次或一次
{n} 重复n次
{n,m} 重复至少n次,但不超过m次
{n,} 重复至少n次
再来试一些例子吧
10. \b\w{5,6}\b (查找五个或六个字母数字字符的字,如as25d、d58sdf等)
11. \b\d{3}\s\d{3}-\d{4} (查找十个数字的电话号码,如800 123-1234)
12. \d{3}-\d{2}-\d{4} (查找社会保险号码,如 123-45-6789)
13. ^\w* (每行或整篇文章的第一个字)
在espresso可试试有multiline和没multiline的不同。
匹配某范围的字符
有时需要查找某些特定的字符时怎么辨?这时中括号”[]”就派上了用场。因此[aeiou]所要查找的是”a”、”e”、”i”、”o”、”u”这些 元音,[.?!]所要查找的是”.”、”?”、”!”这些符号,在中括号中的特殊字符的特别意义都会被移除,也就是解译成单纯的字面意义。也可以指定某些 范围的字符,如”[a-z0-9]”,所指的就是任意小写字母或任意数字。
接下来再看一个比较初复杂查找电话号码的re例子
14. \(?\d{3}[( ] \s?\d{3}[- ]\d{4} (查找十位数字之电话号码,如(080) 333-1234 )
这样的re可查找出较多种格式的电话号码,如(080) 123-4567、511 254 6654等。”\(?”代表一个或零个左小括号”(“, 而”[( ]”代表查找一个右小括号”)”或空格符,”\s?”指一个或零个空格符组。但这样的re会将类似”800) 45-3321”这样的电话找出 来,也就是括号没有对称平衡的问题,之后会学到择一(alternatives)来决解这样的问题。
不包含在某特定字符组里(negation)
有时需要查找在包含在某特定字符组里的字符,下表说明如何做类似这样的描述。
\w 不是字母数字的任意字符
\s 不是空格符的任意字符
\d 不是数字字符的任意字符
\b 不在字边界的位置
[^x] 不是x的任意字符
[^aeiou] 不是a、e、i、o、u的任意字符
15. \s+ (不包含空格符的字符串)
择一(alternatives)
有时会需要查找几个特定的选择,此时””这个特殊字符就派上用场了,举例来说,要查找五个数字及九个数字(有”-”号)的邮政编码。
16. \b\d{5}-\d{4}\b\b\d{5}\b (查找五个数字及九个数字(有”-”号)的邮政编码)
在使用alternatives时需要注意的是前后的次序,因为re在alternatives中会优先选择符合最左边的项目,16中,如果把查找五个数字的项目放在前面,则这re只会找到五个数字的邮政编码。了解了择一,可将14做更好的修正。
1
2下一页阅读全文
标签:
萍乡
江苏
衢州
蚌埠
广元
衡水
大理
枣庄
巨人网络通讯声明:本文标题《Further Study of Rugular Expresions第1/2页》,本文关键词 ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
相关文章
电销机器人到底如何运作的?
很多人对 电销 机器人到底如何运作存在着巨大的好奇心,那么今天,小编就带大家看一下机器人的运作流程! 电销...
10-24
电话机器人的兴起对电销行业来说是“惊喜”还
随着互联网 大数据 的普及,许多 电销 行业如雨后春笋般争先恐后地冒出来。而今电销行业的混乱,让各位涉足电销...
10-24
百应电话机器人有哪些功能?百应电话机器人好
百应 智能 电话机器人 能够协助企业进行呼入接待、 外呼 回访等服务场景,能够经过不断的培训学习,逐步完善成专...
10-24
客服外呼系统都有哪些优势?
当前呼叫中心电话系统被企业用于业务 电销 以及客户服务,然而随着企业需求不断扩大,原来传统的自建 呼叫中心...
10-24
电销机器人效果怎么样?智能电话机器人可行吗
几百数千年后,或许没人会记得卡斯帕罗夫曾是世界第一的围棋高手,但人们会记得,他败给了电脑深蓝。那虽算不...
10-24
百应智能外呼系统,贷后管理科技升级
去年底开始,接连出台政策和法规加强对消费 金融 等金融形态进行 规范 。强 监管 下,行业走向规范发展,行业竞...
10-24
百应智能外呼系统引领外呼行业新风向
电话销售: 您好,我这边是XX地产,给您推荐一下精装酒店式公寓,有兴趣了解一下吗? 客户: 具体位置在哪里啊?...
10-24
小贷企业为什么需要电销机器人?
随着信贷行业逐步进入我们的生活中,越来越多人选择借款来处理资金难题。信贷企业不断涌现,业务开展迅猛,行...
10-24
雷霆电话机器人是如何转接人工的?
当我们在拨通移动、联通或电信 运营商 的客服电话时,总会要先经过一些机械化的选择,然后成功连接人工坐席反馈...
10-24
米卡迪电话机器人效果怎么样?
外呼 电话机器人 ,之所以能智能的与客户无忧交流,因为运用了下面这么多高技术。 ASR 语音识别 米卡迪电话机器人...
10-24
灵声电话机器人效果怎么样?好用吗
外呼 电话机器人 ,之所以能智能的与客户无忧交流,因为运用了下面这么多高技术。 灵声 电话机器人 效果怎么样?...
10-24
电销机器人要想效果好,话术定制有多重要
电话机器人 是基于智能语音技术的智能营销工具。它会像真人一样主动拨打客户的电话,介绍产品并回答客户的咨询...
10-24
智能电话机器人的实现原理,使用安全吗?
随着科学技术的进步和 人工智能 的发展,越来越多的智能产品已经进入我们的工作和生活。智能手机、智能电视、智...
10-24
福州哪里有电话机器人研发公司?
人工智能 再次成为各行各业关注的焦点,自从这个概念首次提出以来,60年已经过去了。自从AlphaGo以巨大优势击败人...
10-24
电销机器人销售能力怎么样?
自从 电话机器人 一出现,在 电销 行业火爆了起来。面对电话机器人的各种优势,企业跃跃欲试,但又害怕效果不理...
10-24
推荐文章
Win10 Mobile预览版10536使用后越来越卡顿
优化产业结构 商务部服务外包研究中心一行来漳调研
科大讯飞“语音云”发布 移动互联网迈入语音时代
习近平叮嘱大庆加快城市转型
加强商标权保护至关重要
MaerskData美国公司选择思科IP电话解决方案
您的联络中心NLP和NLU指南
Win7/Win8.1用户:全新安装Win10之前请先升级
上一篇:
js取得参数代码
下一篇:
正则表达式之全部符号对照表
一起分享吧
版权所有:巨人网络(扬州)科技有限公司——拥有网站建设十年经验,具备独立网站开发能力,能够提供完善的网站设计及相关的网站制作服务! 全国统一服务热线:400-1100-266
展开
收缩
QQ咨询
在线咨询
客服小董
客服小张
客服小刘
客服小李
客服小王
招商加盟
财务查询
微信客服
电话咨询
400-1100-266