Django30——re.findall使用


re.py中定义如下:

def findall(pattern, string, flags=0):
    """Return a list of all non-overlapping matches in the string.
   
    If one or more capturing groups are present in the pattern, return
    a list of groups; this will be a list of tuples if the pattern
    has more than one group.
    
    Empty matches are included in the result."""
    return _compile(pattern, flags).findall(string)

返回string中所有与pattern匹配的全部字符串,返回形式为数组。

1、常用正则表达式

在这里插入图片描述

import re
str = 'aabbabaabbaa'
# .是匹配除 \n (换行符)以外的任意一个字符
print(re.findall(r'a.b',str)) #['aab', 'aab']

# *前面的字符出现0次或以上
print(re.findall(r'a*b',str)) #['aab', 'b', 'ab', 'aab', 'b']

# .* 贪婪,匹配从.*前面为开始到后面为结束的所有内容
print(re.findall(r'a.*b',str)) #['aabbabaabb']

# .*? 非贪婪,遇到开始和结束就进行截取,因此截取多次符合的结果,中间没有字符也会被截取
print(re.findall(r'a.*?b',str)) #['aab', 'ab', 'aab']

# (.*?) 非贪婪,与上面一样,只是与上面的相比多了一个括号,只保留括号的内容
print(re.findall(r'a(.*?)b',str)) #['a', '', 'a']

2、re.S

在这里插入图片描述

import re
str = '''
        aabbab
        aabbaa
        bb
      '''
# 参数无re.S,没有把最后一个换行的aab算进来
print(re.findall(r'a.*?b',str)) #['aab', 'ab', 'aab']

# 参数有re.S,不会对\n进行中断
print(re.findall(r'a.*?b',str,re.S)) #['aab', 'ab', 'aab', 'aa\n        b']
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值