gpt4 book ai didi

python - re.sub 不替换所有事件

转载 作者:太空狗 更新时间:2023-10-29 20:14:34 24 4
gpt4 key购买 nike

我不是 Python 开发人员,但我正在使用 Python 脚本来 convert SQLite to MySQL

建议的脚本很接近,但没有雪茄,正如他们所说。

给我一​​个问题的行是:

line = re.sub(r"([^'])'t'(.)", r"\1THIS_IS_TRUE\2", line)

...当然还有 false ('f') 的等效行。

我看到的问题是任何给定行中只有第一次出现的“t”被替换。

所以,输入脚本,

INSERT INTO "cars" VALUES(56,'Bugatti Veyron','BUG 1',32,'t','t','2011-12-14 18:39:16.556916','2011-12-15 11:25:03.675058','81');

...给...

INSERT INTO "cars" VALUES(56,'Bugatti Veyron','BUG 1',32,THIS_IS_TRUE,'t','2011-12-14 18:39:16.556916','2011-12-15 11:25:03.675058','81');

我提到我不是 Python 开发人员,但我已经尝试自己解决这个问题。根据文档,我知道 re.sub 应该替换所有出现的“t”。

如果有人提示我为什么只看到第一个出现的地方被替换,我将不胜感激,谢谢。

最佳答案

您希望示例中的两个替换重叠 - 't' 的两个实例之间的逗号将在第一种情况下与 (.) 匹配,所以 ([^']) 在第二种情况下永远没有机会匹配它。这个稍作修改的版本可能会有所帮助:

line = re.sub(r"(?<!')'t'(?=.)", r"THIS_IS_TRUE", line)

此版本使用先行和后行语法,描述 here .

关于python - re.sub 不替换所有事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13363473/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com