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 слични објави

Пребарај: #alshabab

当前筛选 #alshabab清除筛选
Borkena

@borkena · Post #6212 · 24.04.2026 г., 16:48

ኮሎኔል ደመቀ ዘውዱ ለሂውማን ራይስት ዋች የሰጡት ምላሽ ፤ መንግስት 5 የኦርቶዶክስ አገልጋዮችን አልሻባብ ጋር ይሰራሉ በሚል ክስ ፍርድ ቤት ማቅረቡ እና ሌሎች ዜናዎች፡፡https://youtu.be/B8XgwPmK0dU#Ethiopia#News#EthiopianNews#Welkait#Orthodox#Alshabab

AI match predictions

@ai_match_prediction · Post #12043 · 11.05.2026 г., 09:05

Saudi-Arabia Pro League🇸🇦 2026-05-11 16:50 UTC NEOM vs. Al Shabab Predicted outcome: NEOM✅ Predicted score: 2:1 Actual: NEOM 2:1 #NEOM#AlShabab 2026-05-11 18:00 UTC Al Taawon vs. Al-Ahli Jeddah Predicted outcome: Al-Ahli Jeddah✅ Predicted score: 1:2 Actual: Al-Ahli Jeddah 1:2 #AlTaawon#AlAhliJeddah #Football#SaudiArabiaProLeague

AI match predictions

@ai_match_prediction · Post #11590 · 19.04.2026 г., 01:05

AFC Challenge League🌏 2026-04-19 09:00 UTC Al-Shabab vs. Al Kuwait Predicted outcome: Draw❌ Predicted score: 1:1 Actual: Al Kuwait 3:5 #AlShabab#AlKuwait 2026-04-19 14:00 UTC Al Ansar vs. Muras United Predicted outcome: Draw❌ Predicted score: 1:1 Actual: Muras United 0:3 #AlAnsar#MurasUnited #Football#AFCChallengeLeague

AI match predictions

@ai_match_prediction · Post #11892 · 03.05.2026 г., 09:05

Saudi-Arabia Pro League🇸🇦 2026-05-03 16:00 UTC Al Shabab vs. Al Taawon Predicted outcome: Al Taawon✅ Predicted score: 2:3 Actual: Al Taawon 1:5 #AlShabab#AlTaawon 2026-05-03 18:00 UTC Al-Ahli Jeddah vs. Al Okhdood Predicted outcome: Al-Ahli Jeddah✅ Predicted score: 4:0 Actual: Al-Ahli Jeddah 4:0 #AlAhliJeddah#AlOkhdood 2026-05-03 18:00 UTC Al-Qadisiyah FC vs. Al-Nassr Predicted outcome: Al-Nassr❌ Predicted score: 1:2 Actual: Al-Qadisiyah FC 3:1 #AlQadisiyah#AlNassr #Football#SaudiArabiaProLeague

AI match predictions

@ai_match_prediction · Post #11322 · 05.04.2026 г., 09:05

Saudi-Arabia Pro League🇸🇦 2026-04-05 15:55 UTC Al Okhdood vs. Al-Fateh Predicted outcome: Al-Fateh❌ Predicted score: 1:2 Actual: Al Okhdood 1:0 #AlOkhdood#AlFateh 2026-04-05 18:00 UTC Al-Ettifaq vs. Al-Qadisiyah FC Predicted outcome: Al-Qadisiyah FC❌ Predicted score: 1:3 Actual: Al-Ettifaq 3:2 #AlEttifaq#AlQadisiyah 2026-04-05 18:00 UTC Al Riyadh vs. Al Shabab Predicted outcome: Draw✅ Predicted score: 1:1 Actual: Draw 1:1 #AlRiyadh#AlShabab #Football#SaudiArabiaProLeague

AI match predictions

@ai_match_prediction · Post #11797 · 28.04.2026 г., 09:05

Saudi-Arabia Pro League🇸🇦 2026-04-28 16:00 UTC Al Shabab vs. Al-Fateh Predicted outcome: Al Shabab❌ Predicted score: 2:1 Actual: Draw 1:1 #AlShabab#AlFateh 2026-04-28 16:45 UTC NEOM vs. Al-Hazm Predicted outcome: NEOM❌ Predicted score: 2:1 Actual: Draw 1:1 #NEOM#AlHazm 2026-04-28 18:00 UTC Al Khaleej Saihat vs. Al Najma Predicted outcome: Al Khaleej Saihat✅ Predicted score: 2:1 Actual: Al Khaleej Saihat 3:1 #AlKhaleejSaihat#AlNajma 2026-04-28 18:00 UTC Al-Hilal Saudi FC vs. Damac Predicted outcome: Al-Hilal Saudi FC✅ Predicted score: 2:1 Actual: Al-Hilal Saudi FC 1:0 #AlHilalSaudi#Damac #Football#SaudiArabiaProLeague