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

Резултати

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

Пребарај: #locali

当前筛选 #locali清除筛选
Libertà è ragione

@libertaeragione · Post #4363 · 02.05.2025 г., 21:47

#Elezioni#RegnoUnito#Locali Risultati definitivi: #Reform|Destra populista: 677 seggi (+677) #LDEM|RE: 370 (+164) #CON|Centro-destra: 317 (-676) #LAB|S&D: 99 (-186) Indipendenti: 88 (-20) #Greens|G/EFA: 80 (+45) #MK|Regionalisti cornici: 3 (-2) Residents' Association: 2 (-1) Ashfield Independents: 1 (-9) @OsservatorioEsteri

Libertà è ragione

@libertaeragione · Post #4421 · 13.10.2025 г., 15:33

#Elezioni#Portogallo#Locali Consigli comunali conquistati: #PSD|EPP e coalizioni: 136 #PS|S&D e coalizioni: 128 #CDS|EPP e coalizioni: 61 Indipendenti e Localisti: 20 #CDU (#PCP-#PEV)|LEFT|G/EFA: 12 *#PPM|ECPP: 7 *#IL|RE: 6 #Chega|PfE: 3 *#PAN|G/EFA: 2 *#LIVRE|G/EFA: 2 *#Volt|G/EFA: 1 #JPP|Centro di Madeira: 1 #NC|Centro-destra: 1 *= in coalizione In foto, la mappa del voto. @OsservatorioEsteri

Libertà è ragione

@libertaeragione · Post #4463 · 23.03.2026 г., 00:18

#Elezioni#Francia#Locali#ÎleDeFrance#Parigi Risultati definitivi: Affluenza: 61,59% Emmanuel #Grégoire (#PS supp. #PP-#EELV-#PCF|S&D|G/EFA|LEFT): 50,52% Rachida #Dati (#LR supp. #MoDem-#UDI-#Horizons|EPP|RE): 41,51% Sophia #Chikirou (#LFI|LEFT): 7,97% Emmanuel Grégoire eletto Sindaco di Parigi. @OsservatorioEsteri

Libertà è ragione

@libertaeragione · Post #4459 · 19.03.2026 г., 13:45

#Elezioni#PaesiBassi#Locali Risultati definitivi dei seggi: Affluenza: 53,7% (+3 rispetto al 2022) Localisti: 3391 seggi (+197) #CDA|EPP: 1110 (-19) #VVD|RE: 1074 (+66) #PvdA-#GL|S&D|G/EFA: 1059 (-138) #D66|RE: 660 (+57) #FvD|ESN: 299 (+244) #SGP|ECR: 256 (+28) #CU|ECPP: 211 (-91) #SP|LEFT: 103 (-65) #PVV|PfE: 101 (+42) #CU-#SGP|ECPP|ECR: 78 (-12) #PvdD|LEFT: 58 (-5) #50PLUS|RE: 39 (+18) #BBB|ECR: 38 (+38) #DENK|Sinistra multiculturale: 31 (+7) #Volt|G/EFA: 25 (+5) #JA21|Destra fortuinista: 17 (+15) #BIJ1|Sinistra radicale: 4 (-2) @OsservatorioEsteri

Libertà è ragione

@libertaeragione · Post #3832 · 20.05.2023 г., 23:36

#Elezioni#RegnoUnito#Locali#NordIrlanda Risultati definitivi: #SF|LEFT: 144 seggi (+39) #DUP|Destra unionista: 122 #APNI|RE: 67 (+14) #UUP|ECR: 54 (-21) #SDLP|S&D: 39 (-20) Indipendenti: 19 (-5) #TUV|Destra unionista: 9 (+3) #GreensNI|G/EFA: 5 (-3) #PBP|LEFT: 2 (-3) #PUP|Sinistra unionista: 1 (-2) #Aontú|Nazionalisti conservatori: 0 (-1) #CCLA|Sinistra: 0 (-1) Per blocchi: Nazionalisti (#SF-#SDLP-#Aontú): 192 Unionisti (#DUP-#UUP-#TUV-#PUP): 191 Non settari (#APNI-#GreensNI-#PBP): 80 @OsservatorioEsteri

Libertà è ragione

@libertaeragione · Post #3951 · 12.09.2023 г., 10:58

#Elezioni#Norvegia#Locali Risultati definitivi: Affluenza: 62,2% #H|EPP: 25,9% #Ap|S&D: 21,7% #FrP|Destra: 11,4% #Sp|Centro ruralista: 8,2% #SV|Sinistra: 6,8% #V|RE: 5% #MDG|G/EFA: 4,1% #KrF|EPP: 4% #R|Estrema sinistra: 3,5% #INP|Destra populista: 3% #Pensjonistpartiet|Pensionati: 1,5% #ND|Destra: 0,5% #K|Destra cristiana: 0,5% #Sentrum|Ecologisti di centro: 0,4% #Lib|Destra libertaria: 0,2% #FNB|Anti-pedaggi: 0,2% #NKP|INITIATIVE: 0,05% #Alliansen|Estrema destra: 0,04% #Kystpartiet|Centro-destra ruralista regionalista: 0,02% #Árja|Centro Sámi: 0,01% #SáB|Minoranza Sámi: 0% @OsservatorioEsteri

Libertà è ragione

@libertaeragione · Post #4457 · 16.03.2026 г., 11:00

#Elezioni#Francia#Locali#ÎleDeFrance#Parigi Risultati preliminari: Emmanuel #Grégoire (#PS supp. #PP-#EELV-#PCF|S&D|G/EFA|LEFT): 38% Rachida #Dati (#LR supp. #MoDem-#UDI|EPP|RE): 25,5% Sophia #Chikirou (#LFI|LEFT): 11,7% Pierre-Yves #Bournazel (#Horizons supp. #Renaissance|RE): 11,3% Sarah #Knafo (#Reconquête|ESN): 10,4% Thierry #Mariani (#RN supp. #UDR|PfE|Destra): 1,6% Blandine #Chauvel (#NPA|Estrema sinistra): 0,7% Marielle #Saulnier (#LO|Estrema sinistra): 0,7% Mahel #PierotGuimbaud (#PT|Estrema sinistra): 0,1% Necessario un secondo turno tra Grégoire, Dati, Chikirou, Bournazel e Knafo. @OsservatorioEsteri