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

Пребарај: #cinemaclub

当前筛选 #cinemaclub清除筛选
Russian House Brussels-Europe

@rushousebrussels · Post #2926 · 24.02.2026 г., 14:16

🇷🇺🇧🇪События этой недели в Русском доме в Брюсселе Дорогие друзья! На этой неделе мы подготовили насыщенную программу — история, литература, кино и русский язык. Каждый сможет найти мероприятие по интересам. 📖25 февраля | 19:00 Исторический клуб Лекция профессора Владимира Ронина «Рождение Королевства Бельгия» (Часть I) Погружение в события 1830 года, формирование независимого государства и роль монархии в истории Бельгии. 📚26 февраля | 11:00 Литературный салон «Поэт и воин: судьба Мусы Джалиля» Встреча, посвящённая жизни и подвигу выдающегося поэта, разговор о мужестве, памяти и силе слова. 🎬26 февраля | 19:00 Киноклуб + программа фестиваля «Short Film Days 2025» Часть III: «Снято в регионах» Современные короткометражные фильмы о культуре, традициях и людях разных регионов России. Показ с английскими субтитрами. 📝27 февраля | 18:30 Мастер-класс по русской грамматике (уровень B1+) Прошедшее, настоящее и будущее время Практическое занятие для тех, кто хочет говорить по-русски уверенно и грамотно. 📍 Место проведения: Русский дом в Брюсселе Некоторые мероприятия требуют регистрации. Мы будем рады видеть вас среди гостей и друзей Русского дома. Ждём вас! 🇷🇺🇧🇪Events This Week at the Russian House in Brussels Dear friends, This week we have prepared a rich and diverse program — history, literature, cinema, and the Russian language. Everyone will find an event of interest. 📖25 February | 19:00 Historical Club Lecture by Professor Vladimir Ronin “The Birth of the Kingdom of Belgium” (Part I) An in-depth look at the events of 1830, the formation of an independent state, and the role of the monarchy in Belgian history. 📚26 February | 11:00 Literary Salon “Poet and Warrior: The Fate of Musa Jalil” A meeting dedicated to the life and heroic legacy of the outstanding poet — a conversation about courage, memory, and the power of the written word. 🎬26 February | 19:00 Cinema Club + “Short Film Days 2025” Festival Program Part III: “Filmed in the Regions” Contemporary short films about culture, traditions, and people from various regions of Russia. Screening with English subtitles. 📝27 February | 18:30 Russian Grammar Workshop (B1+) Past, Present, and Future Tenses A practical session for those who want to speak Russian confidently and accurately. 📍 Venue: Russian House in Brussels Some events require registration. We look forward to welcoming you among the guests and friends of the Russian House. See you soon! #RussianHouseBrussels#Culture#BelgianHistory#MusaJalil#CinemaClub#LearnRussian

Russian House Brussels-Europe

@rushousebrussels · Post #2824 · 21.01.2026 г., 15:12

🎬Cinema Club + Short Film Part I “Stars in Short Films” Dear friends, We are delighted to invite you to an evening of short films at the Russian House Brussels — as part of the international annual festival “Short Film Days 2025.” The programme features a selection of remarkable short films starring well-known Russian actors: 🎞“I Don’t Remember” — Director: Evgeny Tsyganov 🎞“Fuck-Up” — Director: Alexandra Rozovskaya 🎞“About a Cow” — Directors: Nikolai Alekseev, Anton Simukhin 🎞“Not Santa Claus” — Director: Stepan Azaryan 🎞“Married for the Second Time” — Director: Radda Novikova 📅22 January 🕖19:00–21:00 🎟FREE ENTRY (registration required) ⏱88 min 🗣English subtitles 🔞18+ ✅ Free registration — seats are limited. 👉Register here:https://rushouse.be/event/cinema-club-short-film-part-i-stars-in-short-films/ We look forward to seeing you! 🎥✨ #RussianHouseBrussels#CinemaClub#ShortFilmDays#ShortFilms#CultureInBrussels#FreeEvent