re.fullmatch.endpos
函数是用来获取所匹配的字符结束位置的,也就是字符串结尾的位置。它和 re.search()
和 re.match()
函数中的 endpos 参数作用相同,但是 re.fullmatch()
不支持 endpos 参数,所以只能使用 re.fullmatch.endpos
来获取结束位置。
re.fullmatch.endpos
函数一般用在 re.fullmatch()
函数中,用来获取匹配的字符结束位置,其语法如下:
match_obj = re.fullmatch(pattern, string, flags=0)
match_obj.endpos
其中,pattern
是要匹配的正则表达式字符串,string
是要匹配的字符串,flags
是可选的标志位,用来控制正则表达式的匹配方式。返回值 match_obj
是一个 Match
对象,通过 match_obj.endpos
可以获取匹配的字符结束位置。
下面通过两个实例来说明 re.fullmatch.endpos
函数的使用。
import re
pattern = r'\d{4}-\d{2}-\d{2}'
string = '今天是2022-11-30,天气晴朗。'
match_obj = re.fullmatch(pattern, string)
if match_obj:
print(f'匹配结果为: {match_obj.group()},结束位置为: {match_obj.endpos}')
else:
print('没有匹配结果')
输出结果如下:
没有匹配结果
由于本例中的 string
中日期格式不符合正则表达式中的日期格式,所以没有匹配结果。如果 string
中的日期格式符合正则表达式中的日期格式,那么就可以成功匹配,如下所示:
string = '今天是2022-11-30,天气晴朗。'
match_obj = re.fullmatch(pattern, string)
if match_obj:
print(f'匹配结果为: {match_obj.group()},结束位置为: {match_obj.endpos}')
else:
print('没有匹配结果')
输出结果如下:
匹配结果为: 2022-11-30,结束位置为: 18
本例中 match_obj.group()
的值为 2022-11-30
,match_obj.endpos
的值为 18
,即 string
的长度。这说明 fullmatch()
匹配到了整个字符串,匹配的字符结束位置就是字符串结尾的位置。
import re
pattern = r'^[a-zA-Z]+$'
string = 'HelloWorld'
match_obj = re.fullmatch(pattern, string)
if match_obj:
print(f'匹配结果为: {match_obj.group()},结束位置为: {match_obj.endpos}')
else:
print('没有匹配结果')
输出结果如下:
匹配结果为: HelloWorld,结束位置为: 10
本例中 pattern
使用了正则表达式的开始符号 ^
和结束符号 $
,表示只匹配整个字符串,而且只匹配大小写字母。string
包含大小写字母,所以匹配成功。match_obj.group()
的值为 HelloWorld
,match_obj.endpos
的值为 10
,即 string
字符串的长度。这说明 fullmatch()
匹配到的字符结束位置也是字符串结尾的位置。
re.fullmatch()
函数不支持 endpos 参数,所以只能使用 re.fullmatch.endpos
来获取结束位置。fullmatch()
函数匹配成功,那么 endpos
的值就等于字符串的长度。endpos
的值是通过搜索字符串的方式获取的,所以如果字符串中有多个子匹配,那么 endpos
的值就是最大的子匹配的结束位置。fullmatch()
函数匹配失败,那么 endpos
的值就是字符串的长度。本文链接:http://task.lmcjl.com/news/15411.html