本文主要是介绍Python(re_group_learning),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
"""
正则表达式中的分组:
分组的标识形式:()
分组会默认分配组号(组id): 按照从左到右的顺序去数左括号
第一个左括号的id就为1
match object的和组相关的方法
group(int/str): int: 组id 可以是0, 1, 2...
str: 组名
group() == group(0) => 0 代表就是匹配成功的完整结果
group(1) => 只输出组1的匹配结果
group(2) => 只输出组2的匹配结果
groups() => 以元组的形式输出所有组的结果
groupdict() => 我们在给组命名过后,输出所有组的 组名: 匹配结果
\number => 就是引用分组的组号(id) \1 \2
(?…): 这是使用分组的一种语法 后边分组的形式(?xxx)
(?:): 在正则表达式中,前边的分组不能被引用
(?aiLmsux:): 和我们前边使用的re中的flags等效:
re.A, re.I, re.U, re.S, re.X, re.M
(?aiLmsux-imsx:...) : -后跟随的是可选的选项
(?P<name>…): 给分组命名
(?P=name): 反向引用一个命名组合
(?#…): 注释
(?=..): lookahead assertion 正向断言
不消费样式的内容:字符串1(?=字符串2)
在去匹配的时候如果字符串1后边跟的是字符串2,那么匹配成功返回的是字符串1
字符串2不返回,只作为匹配成功的条件
(?!...) negative lookahead assertion 正向断言取反
不消费样式的内容:字符串1(?!字符串2)
在去匹配的时候如果字符串1后边跟的不是字符串2,那么匹配成功返回的是字符串1
字符串2不返回,只作为匹配成功的条件
(?<=...) positive lookbehind assertion 正向后视断定
不消费样式的内容: (?<=字符串2)字符串1
在去匹配的时候如果字符串1前边跟的是字符串2,那么匹配成功返回的是字符串1
字符串2不返回,只作为匹配成功的条件
(?<!...) 不消费样式的内容: (?<!字符串2)字符串1
在去匹配的时候如果字符串1前边跟的不是字符串2,那么匹配成功返回的是字符串1
字符串2不返回,只作为匹配成功的条件
(?(id/name)yes-pattern|no-pattern):
如果给定的 id 或 name 存在,将会尝试匹配 yes-pattern ,
否则就尝试匹配 no-pattern , no-pattern可选
如果< 存在那么我们是要匹配>
如果< 不存在那么我们不匹配>
id: 组id
name: 组名
"""
import re
str_data = "abcd"
pattern = "a(b(c))d" # 两对括号,就由两个分组
match_obj = re.search(pattern, str_data)
print(match_obj)
print(match_obj.group())
print(match_obj.group(0))
print(match_obj.group(1))
print(match_obj.group(2))
print(match_obj.groups())
print(match_obj.groupdict())
# \number => 就是引用分组的组号(id)
str_data = "abcdbcc"
pattern = r"a(b(c))d\1\2"
print(re.search(pattern, str_data))
# (?:)
str_data = "abcdbcc"
pattern = r"a(?:b(c))d\1\2"
# print(re.search(pattern, str_data))
str_data = "abcd"
pattern = "a(?i:BC)d"
print(re.search(pattern, str_data))
str_data = "abcd"
pattern = r"a(?P<g1>b(?P<g2>c))d"
match_obj = re.search(pattern, str_data)
print(match_obj)
print(match_obj.group("g1"))
print(match_obj.group("g2"))
print(match_obj.groupdict())
str_data = "abcdbcc"
pattern = r"a(?P<g1>b(?P<g2>c))d(?P=g1)(?P=g2)"
match_obj = re.search(pattern, str_data)
print(match_obj)
str_data = "abcdbcc"
pattern = r"a(?P<g1>b(?P<g2>c))d(?P=g1)(?P=g2)(?#使用组名引用分组)"
match_obj = re.search(pattern, str_data)
print(match_obj)
str_data2 = "windows10"
str_data = "windows98"
pattern = "windows(?=10)"
print(re.match(pattern, str_data))
print(re.match(pattern, str_data2))
str_data2 = "windows10"
str_data = "windows98"
pattern = "windows(?!10)"
print(re.match(pattern, str_data))
print(re.match(pattern, str_data2))
str_data2 = "windows10"
str_data = "windows98"
pattern = "(?<=windows)10"
print(re.search(pattern, str_data))
print(re.search(pattern, str_data2))
str_data2 = "windows10"
str_data = "Linux10"
pattern = "(?<!windows)10"
print(re.search(pattern, str_data))
print(re.search(pattern, str_data2))
#如果 < 存在那么我们是要匹配 >
#如果 < 不存在那么我们不匹配 >
#(?(id/name)yes-pattern|no-pattern)
pattern = "(<)?\w+@\w+.com(?(1)>|)"
str_data = "<user@host.com>"
str_data2 = "user@host.com"
print(re.search(pattern, str_data))
print(re.search(pattern, str_data2))
pattern = "(?P<g1><)?\w+@\w+.com(?(g1)>|)"
str_data = "<user@host.com>"
str_data2 = "user@host.com"
print(re.search(pattern, str_data))
print(re.search(pattern, str_data2))
"""
1.所有分组的应用:
():
"""
这篇关于Python(re_group_learning)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!