Функция sub в regex может принимать функцию в качестве аргумента repl.
📄 Из документации:
If repl is a function, it is called for every non-overlapping occurrence of pattern. The function takes a single match object argument, and returns the replacement string.
То есть для каждого совпадения будет вызвана функция для вычисления замены вместо замены на одну и ту же строку для всех совпадений.
Иными словами, для замены разных совпадений на разные строки не потребуется запускать re.sub() много раз для каждой строки замены. Достаточно определить функцию, которая вернёт строку для каждого из совпадений.
Описание слишком запутанное🤔, давайте лучше рассмотрим на простом примере:
Создаем карту замены. То есть какие строки на какие требуется менять.
remap = {
'раз': '1',
'два': '2',
'три': '3',
'четыре': '4',
'пять': '5',
}
Пишем функцию поиска строки для замены. Единственным аргументом будет объект re.Match.
Используя данные этого объекта мы вычисляем замену on-the-fly!
def get_str(match: re.Match):
word = match.group(1)
return remap.get(word.lower()) or word
Пример текста.
text = '''Раз Два Три Четыре Пять
Вместе будем мы считать
Пять Четыре Три Два Раз
Мы считать научим вас
'''
Теперь запускаем re.sub и вместо строки замены (repl) подаём имя функции.
(Данный паттерн ищет отдельные слова в тексте)
>>> print(re.sub(r'(\w+)', get_str, text))
1 2 3 4 5
Вместе будем мы считать
5 4 3 2 1
Мы считать научим вас
Думаю, достаточно наглядно 🤓
#libs#regex
#неугомонная#нашфэшн#zarina#MFG
В новой концепции магазинов Zarina мне практически всё нравится и Любовь Аксенова в качестве амбассадора бренда тоже. ❤️
Но вот почему из витринного лайтбокса с фото Любови торчит жуткий чёрный провод — загадка. Видимо, чтобы добавить энергии слегка уставшей диве ⚡️
Можно же доступными средствами скрыть «изнанку» бизнеса и прочий колхоз? ТЦ в Москве, на А начинается.
😍#чтонашла#мненежалко#полный_fashion#MFG
Я как всегда работаю в выходной… закусилась с дружественным арт-директором (у которого черный пояс по шрифтам) на тему брендинга в массовой моде (то, что за границей вполне себе официально именуют mall fashion) и для наглядного обсуждения отправилась искать материалы по идеологии брендОв портфеля MFG (Zarina, Befree, LR, Sela, Idol). Задача оказалась не слишком-то сложной.
В открытом доступе нашелся и очень достойный Отчет по устойчивому развитию за 2022 и Годовой отчет компании за 2023.
Документ особенно пригодится в работе маркетологам ТЦ. Посмотрите на актуальные логотипы магазинов компании и проверьте, что размещено у вас на сайтах ТЦ (у многих древность и старина, но пальцем показывать не буду - сами найдете)
Upd: Там в версткеГодового отчета, где компания хвалится наградами, увиделакак забавно именуют премию вселенского масштаба с трудно произносимым названием Greeeeaaaattt (сама путаюсь в буквах, но их величавое четноеколичество, всё по феншую) - просто SCRUSSIA. Вот так мы её и будем называть - «премия скраша», тыдыщ
Файлики ниже 👇
#нашфэшн#MFG#BeFree#примерочные#неугомонная
Я вот с нетерпением жду сессии про отечественный fashion-ретейл на MallPic в Сочи, которую будет модерировать Игорь Борисыч уважаемый. Особенно интересует вопрос а начали ли российские компании, в связи с открытием Daher brands на месте экс-магазинов Inditex, более тщательно поддерживать порядок в своих торговых точках?
Зашла сегодня в свежайший BeFree в Авиапарке. Дизайн, концепт, мерч — очень круто, молодцы! Но почему в примерочных пыль клубами?
К слову, в 21:00 из 24 примерочных в BF свободна была только одна. Это успешный успех. Ок, допустим, весь легкий бардак в рознице — от покупателей. Согласна: лучше так, чем пустота как в Vilet.
🎥 Репортаж из нового BeFree будет чуть позже. Спойлер: мне очень понравилось, хотя дизайн из серии «найди пять отличий с флагманом GJ на Тверской»
И, да, я придираюсь, но это всё из лучших побуждений ❤️ you know