Небольшой трик с регулярными выражениями который редко вижу в чужом коде.
Допустим, вам нужно распарсить простой текст и вытащить оттуда пары имя+телефон. Вернуть всё это надо в виде списка словарей. Возьмем очень простой пример текста.
>>> text = '''
>>> Alex:8999123456
>>> Mike:+799987654
>>> Oleg:+344456789
>>> '''
Соответственно, для выделения нужных элементов будем использовать группы. Получится такой паттерн:
(\w+):([\d+]+)
Как мы будем формировать словарь из найденных групп?
>>> import re
>>> results = []
>>> for match in re.finditer(r"(\w+):([\d+]+)", text):
>>> results.append({
>>> "name": match.group(1),
>>> "phone": match.group(2)
>>> })
>>> print(results)
[{'name': 'Alex', 'phone': '8999123456'}, ...]
Можно немного сократить запись используя zip
>>> results = []
>>> for match in re.finditer(r"(\w+):([\d+]+)", text):
>>> results.append(dict(zip(['name', 'phone'], match.groups())))
Но есть способ лучше! Это именованные группы в regex. Можно в паттерне указать имя группы и результат сразу забрать в виде словаря.
>>> for match in re.finditer(r"(?P<name>\w+):(?P<phone>[\d+]+)", text):
>>> results.append(match.groupdict())
То есть всё что я сделал, это добавил в начале группы (внутри сбокочек) такую запись:
(?P<group-name>...)
Теперь найденная группа имеет имя и можно обратиться к ней как к элементу списка
>>> name = match['name']
Либо забрать сразу весь словарь методом groupdict()
>>> match.groupdict()
#tricks#regex
Для тех кто не смотрел, очень советую
Серия про ChatGPT на злобу дня 😂
На самом деле там поднимается очень важная мысль, о которой забывает большая часть новичков, ощутивших мощь инструмента и поддавшихся безусловному делегированию мышления. А это не есть хорошо, ведь технология не идеальна и может допускать множество ошибок. Многие перекладывают часть задач на ИИ или даже полностью автоматизируют бизнес. Да, к этому стоит стремиться, но нельзя забывать о тренировке собственного мышления и запасных планах на случай, если всё пойдёт не так.
Был у меня случай, если помнишь, как-то я через агент хотел запостить сообщение в Телегу. В итоге агент шизанул и бахнул пять одинаковых постов подряд, потому что каждый раз замечал ошибку отсутствия ссылки на канале после публикации, что и привело к багу. Самое смешное, что в этот момент я сидел в ресторане, важный такой, рассказываю, что за меня работают роботы... а выключить это безумие не мог, потому что агент запускался на компе, а на телефоне функцию отключения ещё не допилили. XD
Короче, это я к чему. Не отдавайся машине на 100%, оставь хотя бы 50% контроля за собой. Хотя бы сегодня, чтобы ничего не сломать и не отупеть
South Part S27 E3
😂 Поделись своей историей в комментариях
#minds | AcidCrunch
Выйти за рамки
Каждый год в Петербурге проходит «Бессмертный полк» — когда потомки героев войны идут по главным улицам города с их фотографиями, чтобы отдать дань памяти. У меня тоже воевал прадед, и, насколько я знаю, мои родственники участвовали в этом шествии.
Сегодня мне пришла мысль: раз у нас есть хотя бы старая фотография (пусть и не самого лучшего качества), почему бы не оживить её? Улучшить текстуру, добавить объём и даже немного движения — попробовать представить, как бы выглядел мой родственник, если бы он был жив сейчас.
Честно говоря, старые фото у меня всегда вызывали лёгкий страх. В них есть что-то призрачное, словно они не передают настоящего человека, а только нарисованный образ. И мне всегда было сложно понять, каким он был на самом деле. Но сегодня я впервые увидел своего прадеда в объёме — и это был очень необычный, сильный опыт.
А теперь представьте: если подключить воспоминания родителей, бабушек и дедушек — узнать, чем увлекался предок, как он себя вёл, какие у него были привычки — можно не просто восстановить изображение, а выйти за рамки старого, потрескавшегося портрета. Дать ему движение, характер и жизнь.
Ну и с праздником тебя)
👇 Подпишись, сохрани и кидай друзьям
#kling#minds | AcidCrunch