竞彩足球竞彩网app-ctzdesign.com

google seo -> telegram: @ehseo6

">Newsnet 2022-08-10 19:26
  • home  >   /长治闻疚房产交易有限公司  >   竞彩足球竞彩网app
  • 九州视频网址 午夜理论一级在线
    萍乡人才网app 午夜免费影院一二三区
    彩8彩票平台官网app下载 how about 竞彩足球竞彩网app?
    What's the 竞彩足球竞彩网app phone number? What is 竞彩足球竞彩网app contact information ?
    Online consultation 竞彩足球竞彩网app The picture of the 竞彩足球竞彩网app
    竞彩足球竞彩网appof the video Is 竞彩足球竞彩网app for real ?
    竞彩足球竞彩网app's website A map of 竞彩足球竞彩网app
    竞彩足球竞彩网app of tiktok 竞彩足球竞彩网appmusic
    竞彩足球竞彩网app of news 竞彩足球竞彩网appapp
    竞彩足球竞彩网appcompany Customer service of 竞彩足球竞彩网app company

    手机看片午夜福利在线app『网址:ff00.co』 -乐橙app现金网开户-F1F1Y1L1- app下载安卓版V6.3.3-J U pL gjK k r

    成人片下载网址app『网址:ff00.co』 -2018午夜福利最新在线-F1F1Y1L1- app下载安卓版V6.3.3-f WCmn Kf z V

    首页 > 编程 > regex > 正文

    正则表达式之文本模式的匹配和查找

    2022-08-10 21:33:49
    字体:
    来源:转载
    供稿:网友

    1、需求

    我们想要按照特定的文本模式进行匹配或查找。

    2、解决方案

    如果想要匹配的只是简单的文字,那么通常只需要用基本的字符串方法就可以了,比如str.find()、str.endswith()、str.startswith()或类似函数。

    示例:

    text='mark ,帅哥,18,183 帅,mark'print(text=='mark')print(text.startswith('mark'))print(text.startswith('mark'))print(text.find('帅哥'))

    结果:

    False
    True
    True
    6

    如果更为复杂的匹配则需要使用正则表达式以及re模块。为了说明使用正则表达式的基本流程,假设我们想匹配以数字形式构成的日期,比如"11/27/2018"。示例如下:

    import retext1='11/27/2018'text2='Nov 27, 2018'if re.match(r'/d+//d+//d+',text1):  print('符合模型:数字/数字/数字')else:  print('不符合模型:数字/数字/数字')if re.match(r'/d+//d+//d+',text2):  print('符合模型:数字/数字/数字')else:  print('不符合模型:数字/数字/数字')

    运行结果:

    符合模型:数字/数字/数字
    不符合模型:数字/数字/数字

    如果打算针对同一模型做多次匹配,那么通常会先将正则表达式模式预编译成一个模式对象。

    例如:

    import retext1='11/27/2018'text2='Nov 27, 2018'datepat=re.compile(r'/d+//d+//d+')if datepat.match(text1):  print('符合模型:数字/数字/数字')else:  print('不符合模型:数字/数字/数字')if datepat.match(text2):  print('符合模型:数字/数字/数字')else:  print('不符合模型:数字/数字/数字')

    结果:

    符合模型:数字/数字/数字
    不符合模型:数字/数字/数字

    match()方法总是尝试在字符串的开头找到匹配项。如果想针对整个文本搜索出所有的匹配项,那么就应该使用findall()方法,例如:

    import retext='今天是 11/27/2018,昨天是11/26/2018'datepat=re.compile(r'/d+//d+//d+')print(datepat.findall(text))

    运行结果:

    ['11/27/2018', '11/26/2018']

    当定义正则表达式时,我们常会将部分模式用括号包起来的方式引入捕获组,捕获组通常简化后续对匹配文本的处理,因为每个组的内容都可以单独提取出来。findall()方法搜索整个文本并找出所有的匹配项然后将它们以列表的形式返回。如果想以迭代的方式找出匹配项,可以使用finditer()方法。

    例如:

    import re#加入捕获组datepat=re.compile(r'(/d+)+/(/d+)+/(/d+)')m=datepat.match('11/27/2018')print(m.group(0))print(m.group(1))print(m.group(2))print(m.group(3))print(m.groups())month,day,year=m.groups()print(month)print(day)print(year)print('*'*20)text='今天是 11/27/2018,昨天是11/26/2018'for month,day,year in datepat.findall(text):  print('{}-{}-{}'.format(year,month,day))print('*'*20)for m in datepat.finditer(text):  print(m.groups())

    结果:

    11/27/2018
    11
    27
    2018
    ('11', '27', '2018')
    11
    27
    2018
    ********************
    2022-08-10
    2022-08-10
    ********************
    ('11', '27', '2018')
    ('11', '26', '2018')

    3、分析

    本节主要介绍了re模块对文本匹配和搜索的基本功能,首先用re.compile()对模式进行编译,然后使用想match()、findall()、finditer()这样的方法做匹配和搜索。

    当指定模式时我们通常会使用原始字符串,例如:

    r'(/d+)/(/d+)/(/d+)'

    这样的字符串不会对反斜字符转义,这在正则表达式中非常有用。否则,我们需要用双反斜杠线来标识一个单独的'',例如:

    '(//d+)/(//d+)/(//d+)'

    请注意match()方法只会检查字符的开头,有可能出现的匹配的结果并不是你想要的,例如:

    import re#加入捕获组datepat=re.compile(r'(/d+)+/(/d+)+/(/d+)')m=datepat.match('11/27/2018xxxx')print(m)

    结果:

    <re.Match object; span=(0, 10), match='11/27/2018'>

    如果想要精确匹配,可以加一个结束标记:$

    import re#加入捕获组datepat=re.compile(r'(/d+)+/(/d+)+/(/d+)$')m1=datepat.match('11/27/2018xxxx')m2=datepat.match('11/27/2018')print(m1)print(m2)

    结果:

    None
    <re.Match object; span=(0, 10), match='11/27/2018'>

    如果只是执行简单的文本匹配和搜索操作,可以省略编译步骤。
    如果打算执行很多匹配或查找操作的话,通常需要先将模式编译然后重复使用。模块级的函数会对最近编译过的模式做缓存处理,并且比较省步骤。

    总结

    以上所述是小编给大家介绍的正则表达式之文本模式的匹配和查找,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对武林网网站的支持!
    如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

    发表评论 共有条评论
    用户名: 密码:
    验证码: 匿名发表
    水果机 澳门皇冠52H 澳门威尼斯人 皇家永利 财富树
    kok体育 跑的快 癞子牛牛 十大信誉平台 线上赌场
    多福多财 盛大娱乐 耀世娱乐 看四张牛牛 雷泽体育
    看三张牛牛 kok体育 线上百家乐 澳门皇宫娱乐场(赌船) 澳门皇冠