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

Резултати

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

Пребарај: #avs

当前筛选 #avs清除筛选
Ultimora.net - POLITICS 24

@Ultimorapolitics24 · Post #51817 · 01.02.2026 г., 19:48

Referendum giustizia, #AVS ha detto che riserverà agli elettori fuorisede i propri posti per ricoprire il ruolo di rappresentanti di lista ai seggi, in modo che possano votare nel seggio al quale sono assegnati, anche se diverso da quello in cui sono residenti. (ilPost) @UltimoraPolitics24

Hashtags

Noname Research

@zzz_nonameresearch · Post #1995 · 13.02.2026 г., 06:40

#AI#AVs Помимо сильного положительного влияния на роботов, развитие LLM также хорошо влияет на развитие автономных технологий в грузо- и пассажироперпвозках. Поэтому инвестиции в компании разрабатывающие беспилотные авто и грузовики это тоже ахуенная тема. Тейки все такие же. И про снижение себестоимости тоже при росте объемов беспилотных машин в автопарках компаний-операторов грузо- и пассажироперевозок. Скрины в этом посте из того же репорта BofA, что прикреплен выше. В посте ниже ща закину репорт Goldman Sachs по AVs где больше прогнозов по кол-ву машин, penetration в существующий автопарк и прогноз себестоимости производства AVs Из таких компаний держу Pony AI и WeRide

Hashtags

Ultimora.net - POLITICS

@ULTIMORAPOLITICS · Post #44192 · 10.10.2023 г., 15:56

La #Camera approva con 299 sì la risoluzione di maggioranza che impegna il governo a "evitare che arrivino fondi ad Hamas che siano utilizzati per finanziare attacchi terroristici e incitare all'odio verso Israele". Approvate anche le tre risoluzioni presentate dalle opposizioni, con lo stralcio (in quella di #M5S-#PD-#AVS) della parte relativa all'insediamento dei coloni in Cisgiordania @UltimoraPolitics

Ultimora.net - POLITICS

@ULTIMORAPOLITICS · Post #44138 · 30.09.2023 г., 11:00

Il tribunale di Catania accoglie il ricorso di un migrante, sbarcato a Lampedusa e portato nel Cpr di Pozzallo, giudicando il recente decreto del governo "illegittimo in più parti": i giudici contestano la nuova procedura di trattenimento e la cauzione da circa 5.000 euro da pagare per non andare nel centro. #FdI: "Decisione politica e ideologica". #Bonelli (#AVS): "Meloni porta avanti una campagna di distrazione di massa che punta a trasformarla in vittima di un complotto per nascondere le sue incapacità" @UltimoraPolitics

Ultimora.net - POLITICS

@ULTIMORAPOLITICS · Post #42454 · 13.12.2022 г., 12:22

#Senato Approvate le risoluzioni di maggioranza, PD e Terzo Polo, alle comunicazioni del ministro della Difesa, Guido #Crosetto, sul rinnovo dell'autorizzazione all'invio di mezzi militari all'Ucraina. La prima ha ottenuto 143 sì, 29 no e un astenuto. Le altre due 144 voti favorevoli e 28 contrari. Le risoluzioni di #AVS e #M5S non sono state votate @UltimoraPolitics

Ultimora.net - POLITICS

@ULTIMORAPOLITICS · Post #45350 · 12.02.2025 г., 16:37

Confermata in Cassazione la condanna a un anno e sei mesi inflitta per un reato di falso dalla Corte d'appello di Reggio Calabria nell'ottobre 2023 a Mimmo #Lucano, ex sindaco di Riace, oggi eurodeputato nelle liste di #AVS @UltimoraPolitics

Hashtags

Ultimora.net - POLITICS

@ULTIMORAPOLITICS · Post #43171 · 22.03.2023 г., 17:57

#Camera Scontro tra #Meloni e Angelo #Bonelli (#AVS), che ha mostrato due sassi raccolti dal letto del fiume Adige in secca per criticare il governo sul modo con cui sta gestendo il problema della siccità nel Nord Italia. La premier replica: "Non sono Mosè" @UltimoraPolitics

⚽️ 葡萄牙超级联赛 AVS (主) VS 波尔图 (客) 📅开赛时间: 2026-05-11 01:00 📊临场盘赔率(皇冠) ━━━━━━━━━━━━━ 胜平负 主 9.03 平 5.51 客 1.33 让球 半球 +0.5 主 3.53 客 1.32 半/一 +0.5/1主 3.11 客 1.39 一球 +1 主 2.70 客 1.50 一/球半+1/1.5主 2.17 客 1.74 球半 +1.5 主 1.89 客 1.99 球半/两+1.5/2主 1.69 客 2.26 两球 +2 主 1.50 客 2.71 两/两半+2/2.5主 1.40 客 3.04 两半 +2.5 主 1.34 客 3.37 大小球 2.5 大 1.66小 2.29 2.5/3大 1.83小 2.05 2/2.5大 1.49小 2.71 3 大 2.09小 1.79 3/3.5大 2.38小 1.61 3.5 大 2.66小 1.50 1.5 大 1.23小 4.34 4.5 大 4.98小 1.18 ━━━━━━━━━━━━━ 近期交锋:暂无可靠数据 老师胜负预测:客胜 大小球预测:大2.5 波胆预测:1-2 / 1-3 ━━━━━━━━━━━━━ #葡萄牙超级联赛#AVS#波尔图

123•••10•••1314
ПретходнаСтраница 1 од 14Следна