当前位置: 首页 > news >正文

天创网站网站建设柒首先金手指1

天创网站,网站建设柒首先金手指1,新浪短网址,软件开发企业最近因为一些原因频繁使用正则表达式,因为以前系统整理过关于正则表达式的相关知识,所以这里仅记录使用期间遇到的问题。 本文内容基于re包 1. match和search方法的区别 在Python中,re.search和re.match都是用于匹配字符串的正则表达式函数&a…

最近因为一些原因频繁使用正则表达式,因为以前系统整理过关于正则表达式的相关知识,所以这里仅记录使用期间遇到的问题。
本文内容基于re

1. match和search方法的区别

  在Python中,re.searchre.match都是用于匹配字符串的正则表达式函数,但二者在匹配模式上有明显的区别。具体如下:

  • re.match: 该函数只在字符串的开始位置进行匹配。如果开头不匹配,就不会继续匹配下去。其作用类似于从字符串的开位置起寻找能找到符合正则表达式模式的子串。
  • re.search: 该函数会在整个字符串中搜索,直到找到一个匹配的子字符串。其作用类似于从完整的字符串中找到与正则表达式完整匹配的子串。

代码举例如下:

import re
rule=r'(ab|cd).*(ef|gh)' #以ab或cd开头,以ef或gh结尾的字符串
str1='abef'
str2="dcabefabef"
str3="abxyefabstefsc"
print(re.match(rule,str1)) 
print(re.match(rule,str2)) 
print(re.match(rule,str3)) 
print(re.search(rule,str1)) 
print(re.search(rule,str2))
print(re.search(rule,str3)) 

其代码执行结果如下:

<re.Match object; span=(0, 4), match='abef'>
None
<re.Match object; span=(0, 12), match='abxyefabstef'>
<re.Match object; span=(0, 4), match='abef'>
<re.Match object; span=(2, 10), match='abefabef'>
<re.Match object; span=(0, 12), match='abxyefabstef'>

从执行结果中可以发现,这两个方法的返回类型是一样的。
另外,使用^$可以验证完整的字符串是否符合正则表达式规定的模式。具体举例如下:

rule=r'^(ab|cd).*(ef|gh)$' #以ab或cd开头,以ef或gh结尾的字符串
str1='abef'
str2="dcabefabef"
print(re.match(rule,str1)) 
print(re.match(rule,str2)) 
print(re.search(rule,str1)) 
print(re.search(rule,str2))

其执行结果如下:

<re.Match object; span=(0, 4), match='abef'>
None
<re.Match object; span=(0, 4), match='abef'>
None
2. 利用正则表达式实现某些字符必须出现某些字符不能出现的效果

  组合使用零宽断言可以实现利用利用正则表达式实现某些字符必须出现某些字符不能出现的效果。具体举例如下:

rule=r'^(?=.*(ab|cd))(?!.*xy).*$' #ab或cd必须出现,且不能包含xy
str1="132ab23re"
str2="sefeabsefewxyseid"
str3="xyseqeqab"print(re.match(rule,str1))
print(re.match(rule,str2))
print(re.match(rule,str3))

其结果如下:

<re.Match object; span=(0, 9), match='132ab23re'>
None
None

但是在使用这种方式的时候要注意一点(ab|cd)的后面不要添加.*, 这个需要放到xy的前面,否则实现不了同样的效果,展示如下:

import rerule=r'^(?=.*(ab|cd).*)(?!xy)$'
str1="132ab23re"
str2="sefeabsefewxyseid"
str3="xyseqeqab"print(re.match(rule,str1))
print(re.match(rule,str2))
print(re.match(rule,str3))

其执行结果如下:

None
None
None

从结果中我们可以看到,str1和str2是符合要求但结果并没有匹配上。
另外,在这种情况下^$的使用也需要注意,如果不添加这两种断言,结果可能也是错误的。展示如下:

import rerule=r'(?=.*(ab|cd))(?!.*xy)'
str1="132ab23re"
str2="sefeabsefewxyseid"
str3="xyseqeqab"print(re.match(rule,str1))
print(re.match(rule,str2))
print(re.match(rule,str3))

其结果如下:

<re.Match object; span=(0, 0), match=''>
None
None
http://www.yayakq.cn/news/826426/

相关文章:

  • 怎么在网站上投放广告html所有标签大全
  • 茂名建站模板搭建手机网站 qq代码
  • 企业网站建设实例wordpress 导出export.php
  • 建设一个公司网站大概多少钱网络设计工作室
  • 深圳网站设计要点wordpress ios源码
  • 简洁 网站模板站长工具高清无吗
  • 室内设计官方网站网站入口模板
  • 视频解析网站是怎么做的网站建设公司岳阳
  • 宁夏吴忠网站建设信息化网站建设有什么用
  • 广州做网站新锐厦门公司网站建设
  • 网站建设相关语言做问卷调查哪个网站好
  • 微信怎么弄小程序卖东西太原整站优化排名外包
  • 建设网站需要学习什么wordpress网站防护
  • 杭州网站建设公司联系方式淄博安监局网站两体系建设
  • 网站seo公司哪家专业网页游戏开服表送首充
  • 做网站找外包好吗桂林人论坛新鲜事爆料
  • 怎么给自己网站做搜索框wordpress没有票编辑器
  • 响应式网站和普通网站wordpress怎么保存图片
  • 慈溪 网站建设免费下载网站设计方案
  • 网站标题分隔符号wordpress第三方用户系统
  • 婚庆公司网站建设方案网站优化排名提升
  • 免费制作网站平台免密码wifi万能连接
  • 网站建设的图片叠加步骤过程个人商城网站怎么做
  • hp网站12306网站开发投资
  • 网站特效漂亮的网站微信最火公众号排行
  • 在网站底部给网站地图做链接做网站销售的换工作
  • 河南网站建设哪家公司好那家公司网站做的好
  • 网站建设做网站多少钱学生心理健康网站建设论文
  • ps怎么做网站特效比较好的做网站
  • 南京网站外包seo排名优化有哪些