Небольшой трик с регулярными выражениями который редко вижу в чужом коде.
Допустим, вам нужно распарсить простой текст и вытащить оттуда пары имя+телефон. Вернуть всё это надо в виде списка словарей. Возьмем очень простой пример текста.
>>> 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
#EDU hitting the 12H Time frame trendline, in the case of breakout we will have another bullish new trend on this chart💎
❄️@signals_bitcoin_crypto❄️
❄️@Shadow_support0o❄️
#EDU touched the bottom of bullish channel on 1H Time frame we expect it will save this area and will rise again, totally we will wait for correction on this chart
📉
❄️@signals_bitcoin_crypto❄️
❄️@Shadow_support0o❄️
⚡️Домашка декабря. Большой разбор.
[47 min] #edu
Надеюсь, вы хорошо отдохнули и как раз мозг готов переварить новый разбор. Прошелся по работам участников и дополнительно пояснил особенно важные детали.
Очевидно, самое слабое место в задаче — абсолютно непонятная система карточек: не ясно, что будут за задания, нет возможности сравнить их друг с другом, дополнительные задания не отличаются от остальных, но почему-то скрыты в отдельном списке. Вместе разберемся, как пофиксить. Другие сложности — копирайт и запутанная система прохождения заданий. Неочевидно, что будет на следующем шаге, можно ли его прерывать, менять задания и проходить другие. Кто разобрался, тот разобрался.
Решения участников в FIGMA.
❤️ Всем кто качается на праздниках — отдельный лайк!