Регулярно требуется преобразовать какой-либо текст в максимально совместимый текст для 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
Where technology meets global trade: IT leaders driving Retail & Logistics forward
Retail and logistics are being reshaped by real-time supply chains, AI-driven personalization, omnichannel experiences, and end-to-end digital visibility. From global distribution networks to customer-first retail platforms, IT leaders are ensuring speed, resilience, and seamless operations across borders and industries.
👏 Meet the Top 100 IT Leaders nominees in the Retail & Logistics category:
• Kshitij Mulay — Chief Information Officer, Sephora Asia Pte Ltd
•Juliano De Conti — CIO, Total Express
• Majid Khan — Group CIO, U&I Group (Brand owner of J., Almirah and Cast & Crew)
• Rishikesh Singh — Vice President - IT & Digital, Grasim Industries Ltd (Domestic Textiles)
• Diogo Tupinamba — VP IT LATAM & Caribbean, Swissport International AG
• Yuvenna Pillay — Program Director, Pay Inc
• Facundo Saltarelli — CIO & CTO, Car One
• Muhammad Shafique — Project Manager, Orbit Distribution
We are pleased to see you in the list and are truly impressed by your achievements and contribution to the industry!
👉 Now it’s your turn to choose.
Support the IT leaders shaping the future of retail and logistics: https://globalcio.com/top100/rating/retail/
📌 By popular demand, voting has been extended until May 5
#Top100ITLeaders#GlobalCIO#RetailTech#Logistics#DigitalTransformation
📣Рады сообщить, что OSQGROUP выступает официальным партнером ключевого события года в мире retail-технологий — Ритейл ТЕХ Нет 2026
📌 OSQGROUP — партнер мероприятия и спонсор атмосферы.
Это важнейшее и мощнейшее отраслевое событие, объединяющее лидеров рынка, профессионалов и новаторов. Место, где рождаются тренды и заключаются стратегические соглашения.
🎯Когда и где: мероприятие пройдет 21–23 апреля 2026 года в Москве, в Центре Международной Торговли (ЦМТ) . Вас ждут 3 дня насыщенной программы, более 40 деловых потоков и выставка инновационных решений для ритейла.
Будьте в центре главных событий индустрии!
#OSQGROUP#РитейлТЕХНет2026#СпонсорАтмосферы#RetailTech#БизнесСобытие
Рекламный рынок переживает одну из самых больших трансформаций за последние годы.
Причина простая: внимание людей стало самой дорогой валютой.
Если раньше реклама работала по принципу «показал → запомнили»,
то сегодня это выглядит так:
📌 показал → пролистали → забыли.
Именно поэтому главный тренд — реклама через вовлечение.
🔥 Что сейчас работает лучше всего?
1) Большие визуальные форматы
Чем сильнее “вау”, тем выше шанс остановить человека хотя бы на 2–3 секунды.
2) Интерактив и управление вниманием
Клиент не просто смотрит — он взаимодействует.
А взаимодействие всегда сильнее запоминания.
3) Digital-экосистемы вместо “одного экрана”
Сегодня ценится не один носитель, а целая сеть, которая масштабируется и управляется.
4) Реклама, встроенная в покупку
Самый сильный формат — когда реклама не отвлекает, а ведёт к действию.
Реклама будущего — это не баннер.
Реклама будущего — это опыт, эмоция и действие.
#UVBox#интерактив#реклама#digital#ритейл#маркетинг#наружнаяреклама#retailtech