Небольшой трик с регулярными выражениями который редко вижу в чужом коде.
Допустим, вам нужно распарсить простой текст и вытащить оттуда пары имя+телефон. Вернуть всё это надо в виде списка словарей. Возьмем очень простой пример текста.
>>> 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
🔔 Taiko, 내일 Pacaya 하드포크 예정
➡️ 주요 내용
- 지난 몇 달간 엄격한 테스트와 버그 수정 완료
- Multiproving을 포함한 Pacaya 포크
- 1,166,000 블록에서 발생 [2025.5.21 예상]
-베이스드 사전확정 기능 도입
➡️ 거래소 입출금 정지 일정
- 업비트 : 2025.5.20 18:00 ~
- 빗썸 공지는 아직 나오지 않음
*자세한 내용은 아래 원문을 확인하시길 바랍니다
✅원문
✅홈페이지✖️트위터🎮디스코드
#Taiko
Taiko fam, it’s time to step up! 🫵
Prove you’re more than just a wallet address:
- Head over to our new quest on DeBank
- Get your brand-new Taiko Reputation Score
- Receive 100 DeBank XP 🧪
Start here —->
🔗Get Here
Prove your contribution to #Taiko!
💠Nomis tApp | X | Discord | YouTube | Check Scores⚖️
🔴TokenPocket now supports taikoxyz testnet!
You can easily custom add #Taiko Testnet to your wallet in just 3 simple steps!
Guide👉https://help.tokenpocket.pro/en/wallet-operation/how-to-create-a-wallet/taiko
(Both mobile wallet and chrome extension wallet)
✅#Taiko is a fully open source, permissionless, #Ethereum-equivalent ZK-Rollup.
👉https://www.tokenpocket.pro/
👉https://extension.tokenpocket.pro/#/
【Details】https://twitter.com/TokenPocket_TP/status/1751852357602910369
【Powered By】Crypto Box
👓 Let's meet #Taiko🥁! taikoxyz
✅#Taiko is a fully open source, permissionless, #Ethereum-equivalent ZK-Rollup.
Get started with #Taiko's BCR: Taiko's Based Contestable Rollup Quiz & Ecosystem Showcase and Discover it with your #TokenPocket!
👉https://galxe.com/taiko/campaign/GCSaRtw63M
Collect points and enjoy the journey! 💙🩷
【Details】https://twitter.com/TokenPocket_TP/status/1753320975658324290
【Powered By】Crypto Box
Ensemble Kineya — Japon: Nagauta (Ocora, 2000)
#traditional#nagauta#shamisen#taiko#Japan
Japon: Nagauta — альбом ансамбля Kineya, посвящённый вокальному стилю нагаута (長唄), название которого буквально переводится как «длинная песня». Этот жанр возник в XVII веке и с тех пор тесно связан с театром кабуки.
Нагаута сформировался в Эдо, нынешнем Токио, когда музыканты начали исполнять драматические тексты под акомпанемент сямисэна — трёхструнного щипкового инструмента, пришедшего в Японию из Китая через острова Рюкю. Позже к сямисэну добавились ударные и флейты, и сформировался устойчивый ансамбль, ставший частью сценической традиции. В записи представлены композиции в форме, характерной для этого жанра.
🔗Spotify | YouTube | Telegram