Поиск и замена по одному в PythonPython

Программы на Python
Ответить
Anonymous
 Поиск и замена по одному в Python

Сообщение Anonymous »

Я пытаюсь найти закономерности в выражении Markdown. Это мой код:
import re

redmineToGitlabIdMap = dict()
redmineToGitlabIdMap[150767] = { 'iid': 1 }
redmineToGitlabIdMap[150768] = { 'iid': 2 }
redmineToGitlabIdMap[150769] = { 'iid': 3 }

description = '*(from redmine: issue id 150767, created on 2024-02-27 by **me**)*\n\n* Relations:\n * copied_to #150767\n * relates #150768\n * relates #150769'
pattern = r'(\s*\* (?:relates|parent|child|copied_to)) #(\d+)'

for _, redmineId in re.findall(pattern, description):
targetGitlabId = redmineToGitlabIdMap[int(redmineId)]['iid']
description = re.sub(pattern, f'\\1 #{ targetGitlabId }', description, count=1)

print(description)


Как видите, я перебираю совпадения, найденные по регулярному выражению, чтобы одно за другим заменить их соответствующими значениями из словаря redmineToGitlabIdMap.
p>
Однако, когда я это выполняю, он всегда заменяет только самое первое вхождение и возвращает это
* Relations:
* copied_to #3
* relates #150768
* relates #150769

хотя вместо этого следует напечатать следующее:
* Relations:
* copied_to #1
* relates #2
* relates #3


Подробнее здесь: https://stackoverflow.com/questions/792 ... -in-python
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»