久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

re.sub(“。*”,“,”(replacement)“,“ text”)在Python 3.7上的替換次數(shù)翻倍

瀏覽:4日期:2022-08-07 11:56:20
如何解決re.sub(“。*”,“,”(replacement)“,“ text”)在Python 3.7上的替換次數(shù)翻倍?

這不是一個(gè)錯(cuò)誤,而是來自提交fbb490fd2f38bd817d99c20c05121ad0168a38ee的Python3.7中的錯(cuò)誤修復(fù)。

在正則表達(dá)式中,非零寬度的匹配將指針位置移動(dòng)到匹配的末尾,以便下一個(gè)斷言(無論是否為零寬度)都可以從匹配之后的位置繼續(xù)進(jìn)行匹配。因此,在您的示例中,在.*貪婪地匹配并消耗了整個(gè)字符串之后,指針隨后移至字符串末尾的事實(shí)實(shí)際上仍然為該位置的零寬度匹配留有“余地”,這可以從以下代碼,在Python2.7、3.6和3.7中的行為相同:

>>> re.findall('.*', ’sample text’)[’sample text’, ’’]

因此,該錯(cuò)誤修復(fù)程序是在非零寬度匹配之后立即替換零寬度匹配,現(xiàn)在可以用替換文本正確替換兩個(gè)匹配。

解決方法

在Python 3.7(在Windows 64位上測(cè)試)上,使用RegEx替換字符串.*會(huì)使輸入字符串重復(fù)兩次!

在Python 3.7.2上:

>>> import re>>> re.sub('.*','(replacement)','sample text')’(replacement)(replacement)’

在Python 3.6.4上:

>>> import re>>> re.sub('.*','sample text')’(replacement)’

在Python 2.7.5(32位)上:

>>> import re>>> re.sub('.*','sample text')’(replacement)’

怎么了?如何解決?

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 阿瓦提县| 邯郸县| 镶黄旗| 柳江县| 舟曲县| 子长县| 庆云县| 黎川县| 虎林市| 秦安县| 南漳县| 寿光市| 吉林省| 永善县| 土默特左旗| 礼泉县| 广西| 大英县| 长兴县| 临夏市| 肥东县| 称多县| 游戏| 广饶县| 弋阳县| 乐清市| 铁岭县| 海伦市| 托克逊县| 巨鹿县| 丰宁| 阳朔县| 高唐县| 宁晋县| 马山县| 东海县| 哈密市| 枝江市| 东乡县| 兴海县| 景德镇市|