TGTGInsighttelegram intelligenceLIVE / telegram public index
← Python Заметки

TGINSIGHT SIMILAR POSTS

Најди сличен содржај

Изворен канал @pythonotes · Post #65 · 8 апр.

Небольшой трик с регулярными выражениями который редко вижу в чужом коде. Допустим, вам нужно распарсить простой текст и вытащить оттуда пары имя+телефон. Вернуть всё это надо в виде списка словарей. Возьмем очень простой пример текста. >>> 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

Резултати

Пронајдени 1 слични објави

Пребарај: #skeptikbek

当前筛选 #skeptikbek清除筛选

Сегодня заметил интересную цифру в профиле. Нас стало 10 000. Честно говоря, для меня это первый серьезный психологический барьер. Кто бы мог подумать, что столько людей добровольно подпишется на то, чтобы читать мои порой язвительные заметки, изучать узбекский язык без «сахара» и смотреть правде в глаза, какой бы неудобной она ни была? Видимо, скептицизм и тяга к знаниям все-таки заразны. Или вам просто нравится наблюдать, как я ворчу на несправедливость и коверкание языка. В любом случае, я рад, что мы собрали в Фэйсбуке аудиторию думающих людей. Спасибо, что читаете, спорите и учитесь. Идем к следующему барьеру. P.S. Кстати, обратите внимание на число моих подписок рядом — 666. Идеальный баланс, я считаю. 😏 #SkeptikBek#10k#УзбекскийЯзык#МыслиВслух#БекзодРустамбеков t.me/skeptikbek