(如果这是重复的道歉,但不可能google / search $!)
我正在寻找与Perl的$aka $LAST_PAREN_MATCH最接近/最佳等价物.
对于那些不了解Perl的人来说,它的描述如下:
$LAST_PAREN_MATCH
$+ The text matched by the last bracket of the last successful search
pattern. This is useful if you don't know which one of a set of
alternative patterns matched.
也就是说,如果我有一个像(b)|(a)|(r)这样的模式,那么$将包含b,a或r,具体取决于匹配的子模式.
我拥有的最好的是
next((g for g in reversed(match.groups(None)) if g is not None),None)[0]
对于长期的Perl黑客而言,这似乎是一个简单的代码.
(不是说我不知道我可以将它包装在函数last_paren_match(匹配)中:-)
解决方法:
在Python中可能没有等价物,但是如果你使用分支重置模式(?| …)则每个交替管道都有在模式中将重置捕获变量的计数器.我很确定Python会支持它
在此示例中,所有捕获组都保存在$1中
use strict;
use warnings 'all';
use feature 'say';
'zax' =~ /(?|(b)|(a)|(r))/;
say $1;
产量
a
标签:python,perl,regex-group 来源: https://codeday.me/bug/20190724/1523431.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。