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

Резултати

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

Пребарај: #luxuryonwheels

当前筛选 #luxuryonwheels清除筛选
Auto Life

@revheadcrypto · Post #537 · 30.09.2024 г., 05:55

▎🌿 Introducing the Mazda EZ-6: The Green Liftback! 🚗💚 The Mazda EZ-6, developed in collaboration with Changan, is considered the indirect successor to the iconic gasoline "Six." This innovative model will be available in seven versions — four hybrid and three fully electric options! ⚡️ 🔋Fully Electric Version: - Power: 258 hp electric motor on the rear axle. 🔄Hybrid Versions: - Engine: 1.5L, 95 hp gasoline generator. - Electric Motor: 218 hp for driving wheels. ✨Luxurious Features: - Leather upholstery (base model) - Premium leather and suede options (higher trims) - Sony audio system with 14 speakers 🎶 - Ambient interior lighting 🌈 - Zero-gravity front seats for ultimate comfort 🛋️ - Panoramic sunroof 🌌 - Wireless smartphone charging 📱 - Advanced cruise control 🚦 - 14.6-inch media system powered by Qualcomm Snapdragon 8155. 💰Price Range: 160,000 to 200,000 CNY ($22,800 – $28,500 USD). #MazdaEZ6#GreenDriving#ElectricVehicle#HybridTechnology#LuxuryOnWheels#Auto

Auto Life

@revheadcrypto · Post #414 · 31.08.2024 г., 16:58

🚗✨Introducing the All-New Volkswagen Passat in China!🇨🇳 Say hello to the latest sedan that combines sleek design with innovative features! While it may resemble the European wagon, the Chinese Passat boasts a unique look with aggressive bumpers and stylish black accents. 😍 🌟Key Features: - 11.6-inch Passenger Display for ultimate entertainment! 📱 - Convenient Seat Adjustment Button for rear passengers to maximize comfort! 🪑 Under the hood, choose between two powerful turbo engines: - 1.5L with 160 hp ⚡️ - 2.0L with 220 hp 🚀 🗓️Sales Begin on September 10th! #Volkswagen#Passat#NewRelease#China#CarEnthusiasts#Innovation#LuxuryOnWheels#Auto

Auto Life

@revheadcrypto · Post #263 · 07.08.2024 г., 18:21

🚗✨Exciting News: Huawei and BAIC's Stelato S9 Gets a Price Cut!✨🚗 The local competitor to the Mercedes-Benz EQS has just launched pre-orders at a new, lower price! Originally priced between 450,000 and 550,000 yuan (approximately $62,000 to $76,000), the Stelato S9 is now available for just 399,800 to 449,800 yuan (about $56,000 to $63,000)! 💰🎉 The base model features a powerful 309-horsepower rear motor, while the premium versions come with an additional front motor boasting 215 horsepower. 🏎️💨 This electric sedan can accelerate from 0 to 100 km/h in just 3.9 seconds! ⚡️🔥 #StelatoS9#Huawei#BAIC#ElectricSedan#PriceCut#LuxuryOnWheels#Auto