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

TGINSIGHT SIMILAR POSTS

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

Изворен канал @pythonotes · Post #121 · 20 јул.

Регулярно требуется преобразовать какой-либо текст в максимально совместимый текст для URL, имени файла, имени объекта в каком-то софте и тд. Требования совместимости простые: в тексте должны быть только допустимые символы. Обычно это a-z, 0-9 и "_" или "-". То есть, только прописные буквы латинского алфавита и цифры (как пример). Допустим, нам нужно название статьи в блоге преобразовать в slug для добавления его в URL этой статьи. Как это лучше всего сделать? В Django по умолчанию есть готовая функция slugify для таких случаев. Но я её никогда не использую. Почему? Потому что её недостаточно! Приведём пример >>> from django.utils.text import slugify >>> slugify('This is a Title') 'this-is-a-title' Пока всё отлично >>> slugify('This is a "Title!"') 'this-is-a-title' Спец символы удалились, всё хорошо. >>> slugify('Это заголовок статьи') '' Вот и приехали 😢. Если текст не английский то буквы просто игнорируются. Можно это поправить >>> slugify('Это заголовок статьи', allow_unicode=True) 'это-заголовок-статьи' Но тогда мы не вписываемся в условие. У нас появилась кириллица в тексте. Так как я часто пишу сайты для русскоязычных пользователей эта проблема весьма актуальна. Я не использую стандартную функцию и всегда пишу свою. Оригинал я не беру в расчёт и пишу полностью свою функцию. И так, по порядку: 🔸1. Исходный текст: >>> text = 'Мой заголовок №10 😁!' Взял специально посложней со специальными символами. 🔸2. Транслит Необходимо сделать транслит всех символов в латиницу. Здесь очень выручает библиотека unidecode. Помимо простого транслита кириллицы в латиницу она умеет преобразовывать спец символы и иероглифы в текстовые аналоги. from unidecode import unidecode >>> unidecode("Ñ Σ ® µ ¶ ¼ 月 山") 'N S (r) u P 1/4 Yue Shan' Очень крутая библиотека, советую👍 В нашем случае получаем такое преобразование: >>> text = unidecode(text) >>> print(text) 'Moi zagolovok No. 10 !' Отличный транслит. Смайл просто удалился, хотя я ждал что-то вроде :). Ну и ладно, всë равно невалидные символы. А еще наш код уже поддерживает любой язык, будь то хинди или корейский. 🔸4. Фильтр символов Unidecode не занимается фильтрацией по недопустимым символам. Это мы делаем в следующем шаге через regex. Просто заменим все символы на "_" если они вне указанного диапазона. >>> text = re.sub(r'[^a-zA-Z0-9]+', '_', text) >>> print(text) 'Moi_zagolovok_No_10_' Символ "+" в паттерне выручает когда несколько недопустимых символов идут рядом. Все они заменяются на один символ "_". 🔸5. Slugify Осталось удалить лишние символы по краям и сделать нижний регистр >>> text = text.strip('_').lower() >>> print(text) 'moi_zagolovok_no_10' Получаем отличный slug! 😎 🌎 Полный код в виде функции. ______________ PS. Проверку что в строке остался хоть один допустимый символ я бы вынес в отдельную функцию. #libs#tricks#django

Резултати

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

Пребарај: #trp

当前筛选 #trp清除筛选
NIDO Russia (НИДО)

@nido_russia · Post #1661 · 23.06.2024 г., 12:26

📢 On July 1, 2024 , a law comes into force that provides for a 20% indexation of state fees. So from 1 July, state fees for a number of state services will increase: 🔸 Temporary residence permit: from 1600 to 1920 Rubles; 🔸 Residence permit: from 5000 to 6000 Rubles; 🔸 Russian citizenship: from 3500 to 4200 Rubles; 🔸 Registration at the place of residence: from 350 to 420 Rubles; 🔸 Visa renewal: from 1000 to 1200 Rubles; 🔸 Issuance of invitations to the Russian Federation: from 800 to 960 Rubles; 🔸 Work permit: from 3500 to 4200 Rubles; 🔸 Permit to hire foreign workers: from 10,000 to 12,000 Rubles; 🔸 Travel passport; from 5000 to 6000 Rubles; 🔸 Travel passport up to 14 years old: from 2500 to 3000 Rubles. ❗️ Make all relevant applications before 1 July, to avoid paying the new rate. #state_fee#госпошлина#TRP#RP#RVP#VNZH#citizenship#nido#nidorussia Subscribe: @nido_russia https://t.me/nido_russia/1661

Libertà è ragione

@libertaeragione · Post #4456 · 12.03.2026 г., 11:21

#Elezioni#Thailandia Risultati definitivi: Affluenza: 71,43% (-4,28 rispetto al 2023) #BJT|Destra populista: 192 seggi (+121 rispetto al 2023) #PPLE|Centro-sinistra: 120 (-31) #PTP|Centro-destra populista: 74 (-67) #KT|Centro-destra localista: 58 (+58) #DP|Centro-destra: 21 (-4) Altri: 8 #TRP|Centro populista progressista: 6 (+4) #PPRP|Destra militarista: 5 (-35) #PCC|Centro: 5 (-4) #ECON|Estrema destra libertaria: 3 (+3) #TST|Conservatori progressisti: 2 (-4) #UTN|Destra militarista: 2 (-34) #NDPT|Centro-sinistra: 1 #NOP|Centro-destra monarchico: 1 (+1) #TLP|Centro anti-militarista: 1 #TPP|Estrema destra monarchica: 1 (+1) #TTPP|Centro-sinistra: 0 (-1) #PTC|Centro-destra localista: 0 (-1) #FA|Centro: 0 (-1) Totale seggi: 500 Maggioranza: 251 In foto, la mappa del voto. @OsservatorioEsteri