zoukankan      html  css  js  c++  java
  • 正则表达式基本用法

      喜欢我的博客可以加关注,有问题可以提问我。

      首先,我们来看看基本的正则表达式有哪些:

      1.最常规的匹配(匹配所有的字符)

    import re
    content = 'Hello 123 4567 World_this is a Regex Demo'
    print(len(content))
    result = re.match('^Hellosdddsd{4}sw{10}.*Demo$',content)
    print(result)
    print(result.group())
    print(result.span())

      2.范匹配

    import re
    content = 'Hello 123 4567 World_this is a Regex Demo'
    result = re.match('^Hello.*Demo$',content)
    print(result)
    print(result.group())
    print(result.span())
    
    结果:
    <_sre.SRE_Match object; span=(0, 41), match='Hello 123 4567 World_this is a Regex Demo'>
    Hello 123 4567 World_this is a Regex Demo
    (0, 41)

      3.匹配目标

    import re
    content = 'Hello 1234567 World_this is a Regex Demo'
    result=re.match('^Hellos(d+)sWorld.*Demo$',content)
    print(result)
    print(result.group(1))
    print(result.span())
    
    结果:
    <_sre.SRE_Match object; span=(0, 40), match='Hello 1234567 World_this is a Regex Demo'>
    1234567
    (0, 40)

      4.贪婪匹配

    import re
    content = 'Hello 1234567 World_this is a Regex Demo'
    result=re.match('^He.*(d+).*Demo$',content)
    print(result)
    print(result.group(1))
    
    结果:
    <_sre.SRE_Match object; span=(0, 40), match='Hello 1234567 World_this is a Regex Demo'>
    7

      5.非贪婪匹配

    import re
    content = "Hello 1234567 World_this is a Regex Demo"
    result=re.match('^He.*?(d+).*Demo$',content)
    print(result)
    print(result.group(1))
    
    结果:
    <_sre.SRE_Match object; span=(0, 40), match='Hello 1234567 World_this is a Regex Demo'>
    1234567

      6.匹配模式

    import re
    content = 'Hello 1234567 World_this 
    is a Regex Demo'
    result=re.match('^He.*?(d+).*Demo$',content,re.S)
    print(result)
    print(result.group(1))
    print(content)
    
    结果:
    <_sre.SRE_Match object; span=(0, 41), match='Hello 1234567 World_this 
    is a Regex Demo'>
    1234567
    Hello 1234567 World_this 
    is a Regex Demo

      7.转义

    import re
    content = 'price is $5.00'
    result=re.match('price is $5.00',content)
    print(result)
    
    结果:None
    
    import re
    content = 'price is $5.00'
    result=re.match('price is $5.00',content)
    print(result)
    
    结果:<_sre.SRE_Match object; span=(0, 14), match='price is $5.00'>

      8.re.search

    import re
    content = 'Extra stings Hello 1234567 World_this is a Regex Demo Extra stings'
    result=re.match('Hello.*?(d+).*Demo',content)
    print(result)
    
    结果:None
    
    import re
    content = 'Extra stings Hello 1234567 World_this is a Regex Demo Extra stings'
    result=re.search('Hello.*?(d+).*Demo',content)
    print(result)
    print(result.group(1))
    
    结果:
    <_sre.SRE_Match object; span=(13, 53), match='Hello 1234567 World_this is a Regex Demo'>
    1234567
  • 相关阅读:
    2. 获取access_token
    1. 钉钉可以做什么
    3.5 创建模型-关系
    3.5 创建模型 其它
    3.3 创建模型 阴影属性
    3.4 创建模型-并发标记
    Spark运行CDH6.3.2碰到的由于hive驱动引起的问题解决方法
    Spark中碰到需要转义的|分隔符填坑方法
    Spark2 Can't write dataframe to parquet hive table : HiveFileFormat`. It doesn't match the specified format `ParquetFileFormat`.
    Spark连接CDH平台thriftserver和kerberos访问不一致错误排查
  • 原文地址:https://www.cnblogs.com/zll20153246/p/9632662.html
Copyright © 2011-2022 走看看