zoukankan      html  css  js  c++  java
  • re模块

    re模块(正则表达式
      正则就是用一些具有特殊含义的符号组合到一起(称为正则表达式)来描述字符或者字符串的方法。
    或者说:正则就是用来描述一类事物的规则。(在Python中)它内嵌在Python中,并通过 re 模块实现。
    正则表达式模式被编译成一系列的字节码,然后由用 C 编写的匹配引擎执行。

    re模块

    案例

    import re

    # print(re.findall('w','aAbc123_*()-='))
    # print(re.findall('W','aAbc123_*()-= '))
    # print(re.findall('s','aA bc 12f3_*()-= '))
    # print(re.findall('S','aA bc 12f3_*()-= '))
    # print(re.findall('d','aA bc 12f3_*()-= '))
    # print(re.findall('D','aA bc 12f3_*()-= '))
    # print(re.findall('D','aA bc 12f3_*()-= '))
    # print(re.findall('Aalex',' alexis alex sb'))
    # alex
    # print(re.findall('sb',' alexis alexsb sb'))
    # sb
    # print(re.findall('sb',"""alex
    # alexis
    # alex
    # sb
    # """))

    # print(re.findall('^alex','alexis alex sb'))
    # print(re.findall('sb$','alexis alex sb'))
    # print(re.findall('sb$',"""alex
    # alexis
    # alex
    # sb
    # """))

    # print(re.findall('^alex$','alexis alex sb'))
    # print(re.findall('^alex$','al ex'))
    # print(re.findall('^alex$','alex'))

    # 重复匹配:| . | * | ? | .* | .*? | + | {n,m} |
    # 1、.:匹配除了 之外任意一个字符,指定re.DOTALL之后才能匹配换行符
    # print(re.findall('a.b','a1b a2b a b abbbb a b a b a*b'))
    # a.b
    # ['a1b','a2b','a b','abb','a b','a*b']
    # print(re.findall('a.b','a1b a2b a b abbbb a b a b a*b',re.DOTALL))

    # 2、*:左侧字符重复0次或无穷次,性格贪婪
    # print(re.findall('ab*','a ab abb abbbbbbbb bbbbbbbb'))
    # ab*
    #['a','ab','abb','abbbbbbbb']

    # 3、+:左侧字符重复1次或无穷次,性格贪婪
    # print(re.findall('ab+','a ab abb abbbbbbbb bbbbbbbb'))
    # ab+

    # 4、?:左侧字符重复0次或1次,性格贪婪
    # print(re.findall('ab?','a ab abb abbbbbbbb bbbbbbbb'))
    # ab?
    # ['a','ab','ab','ab']

    # 5、{n,m}:左侧字符重复n次到m次,性格贪婪
    # {0,} => *
    # {1,} => +
    # {0,1} => ?
    # {n}单独一个n代表只出现n次,多一次不行少一次也不行

    # print(re.findall('ab{2,5}','a ab abb abbb abbbb abbbbbbbb bbbbbbbb'))
    # ab{2,5}
    # ['abb','abbb','abbbb','abbbbb]

    # print(re.findall('d+.?d*',"asdfasdf123as1111111.123dfa12adsf1asdf3"))


    # []匹配指定字符一个
    # print(re.findall('adb','a1111111b a3b a4b a9b aXb a b a b',re.DOTALL))
    # print(re.findall('a[501234]b','a1111111b a3b a4b a9b aXb a b a b',re.DOTALL))
    # print(re.findall('a[0-5]b','a1111111b a3b a1b a0b a4b a9b aXb a b a b',re.DOTALL))
    # print(re.findall('a[0-9a-zA-Z]b','a1111111b axb a3b a1b a0b a4b a9b aXb a b a b',re.DOTALL))
    #
    # print(re.findall('a[^0-9a-zA-Z]b','a1111111b axb a3b a1b a0b a4b a9b aXb a b a b',re.DOTALL))
    # print(re.findall('a-b','a-b aXb a b a b',re.DOTALL))
    print(re.findall('a[-0-9 ]b','a-b a0b a1b a8b aXb a b a b',re.DOTALL))
  • 相关阅读:
    POJ 1330:Nearest Common Ancestors【lca】
    图论中一类问题的总结 :必须边(点) 可行边(点)
    POJ 1486 Sorting Slides【二分图匹配】
    POJ 2375 Cow Ski Area【tarjan】
    Unity打开AppStore进行评论
    Unity3D UGUI不规则图片点击事件处理
    Unity3D之聊天框怎么跟随内容大小而变换
    Unity3D之小物体层消隐技术
    Unity3D之新手引导(责任链模式)
    Unity3D之FSM有限状态机
  • 原文地址:https://www.cnblogs.com/h1227/p/12615029.html
Copyright © 2011-2022 走看看