>>> a = '0102030405' >>> b = re.sub(r'(?=(?:\d{2})+$)',',',a) >>> b ',01,02,03,04,05'
求助帮忙详细解释下(?=(?:\d{2})+?$)这段正则的意思,这些正则拆开来看我都知道是什么,例如(?=我知道是零宽断言,(?:是捕获不分组。但放在一起就不太明白具体...
求助帮忙详细解释下(?=(?:\d{2})+?$)这段正则的意思,这些正则拆开来看我都知道是什么,例如(?= 我知道是零宽断言,(?: 是捕获不分组。但放在一起就不太明白具体什么意思了。
再帮忙优化下这个正则,使其能够把',01,02,03,04,05',01前面的,去掉,最终使b = '01,02,03,04,05' 展开
再帮忙优化下这个正则,使其能够把',01,02,03,04,05',01前面的,去掉,最终使b = '01,02,03,04,05' 展开
1个回答
展开全部
(r'(?=(?:\d{2})+$)',',',a)
你对这个感到迷惑不奇怪,因为这个写的不简洁,直接(?=(\d{2})+$)的效果和(?=(?:\d{2})+$)的效果是一样的,因为?=已经表示右边定位偶数个数字且非捕获,直到该字符结束。
之所以在01前会有个逗号是因为01前面的位置也匹配到了这个正则,这个位置后面也满足偶数个数字。只需要再加一个非捕获条件即可,这个条件就是定位的位置前面需要有一个数字,也就是非行首。
代码如下:
import re
a = '0102030405'
b = re.sub(r'(?<=(\d))(?=(\d{2})+$)',',',a)
print b
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询