Небольшой трик с регулярными выражениями который редко вижу в чужом коде.
Допустим, вам нужно распарсить простой текст и вытащить оттуда пары имя+телефон. Вернуть всё это надо в виде списка словарей. Возьмем очень простой пример текста.
>>> 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
#soliq_qarzi#billing
📣1 млн сўмдан ошган солиқ қарздорлигини ундиришда электр энергиясининг биллинг тизими механизми жорий этилмоқда
💬Facebook
📸Instagram
📹Youtube
✅ «O‘zbekiston MET» AJ Axborot xizmati
#soliq_qarzi#billing
📣1 млн сўмдан ошган солиқ қарздорлигини ундиришда электр энергиясининг биллинг тизими механизми жорий этилмоқда
💬Facebook
📸Instagram
📹Youtube
✅ «O‘zbekiston MET» AJ Axborot xizmati
#soliq_qarzi#billing
1 mln soʻmdan oshgan soliq qarzdorligini undirishda elektr energiyasining billing tizimi mexanizmi joriy etilmoqda
Het.uz | Facebook | Instagram | YouTube | Telegram
#TozaMakon#Billing#Toshkent
❌Toshkentda chiqindi xizmatidan qarzdor 6 ming ta abonentning elektr to‘loviga vaqtincha cheklov o‘rnatildi
Joriy yilning 5-noyabr kuni Toshkent shahri bo‘yicha chiqindi xizmatlaridan yuzaga kelgan qariyb 2 mlrd 239 mln so‘m debitor qarzdorlik uchun jami 25 ming 121 ta abonent “Hududiy elektr tarmoqlari” AJning “2100” qisqa raqamidan “SMS” xabarnoma orqali ogohlantirildi. Ushbu ogohlantirish yuborilganidan keyin 5 (besh) kun ichida qarzdorlikni bartaraf etmagan 6 ming ta abonentning elektr energiyasi uchun to‘lov qilish imkoniyatiga bugundan vaqtincha cheklov joriy etildi. Ayni paytda Toshkent shahri kesimida chiqindi xizmatlaridan jami 582 mln so‘mdan ortiq debitor qarzdorlik mavjud.
Batafsil saytimizda o'qing!
_______
В Ташкенте временно ограничена возможность оплаты электроэнергии у 6 тысяч абонентов, задолжавших за услуги по вывозу отходов
5 ноября текущего года по городу Ташкент за задолженность по услугам по вывозу отходов на сумму около 2 млрд 239 млн сумов 25 121 абонент был уведомлён посредством SMS-сообщений с короткого номера «2100» АО «Региональные электрические сети». Абонентам, которые в течение пяти дней после получения уведомления не погасили задолженность, с сегодняшнего дня временно ограничена возможность оплаты электроэнергии. На данный момент по городу Ташкент общая дебиторская задолженность за услуги по вывозу отходов превышает 582 млн сумов.
Читайте подробнее на нашем сайте!
Kanalimizga obuna bo'ling: @wasteuzgroup
📷Instagram | 🕊Telegram | 📱Facebook|Web-Sayt
#php#billing#codeigniter#crm#invoiceplane#invoices#invoicing#open_source#php
InvoicePlane is a free, open-source app you host yourself to easily create and manage professional invoices, quotes, clients, payments, and reports. Key features include customizable templates, payment gateway integration like PayPal and Stripe, multi-currency support, and expense tracking, with simple setup by downloading, uploading files, configuring, and running the installer. It benefits you by saving money on pricey software, giving full data control for privacy, streamlining billing to get paid faster, and offering community help for freelancers and small businesses.
https://github.com/InvoicePlane/InvoicePlane