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

Пребарај: #7z

当前筛选 #7z清除筛选
QQ资源岛-破解软件分享

@QQZYDAPP · Post #5654 · 16.04.2026 г., 10:37

⭐️【资源名称】最强7z压缩器ZArchiver Pro v1.2.2专业版 53 🤖【适用平台】: #Andoid 🧱【资源介绍】 ZArchiver是一款强大的压缩和解压缩软件,支持RAR,ZIP,7z等等,不像Androidzip一样解压7z错误,还支持带密码的RAR压缩文件,支持中文文件名(这是安卓上唯一的)支持RAR,ZIP,7z的解压,还支持带密码的解压缩文件,还支持分卷解压,速度和成功率绝对强于其他解压缩软件。 🟡在线下载:点击下载 📁#7z#压缩器

纯情男高

@hanzichen · Post #1130 · 24.09.2025 г., 01:50

7zSfxTool:7zip自解压生成工具v3.6.1.200(清爽版) 软件需要简单学习研究下,阿喵我测试了下,可玩性还是可以的。制作一个自解压的文件,也不复杂 🏷标签:#windows#7z#自解压 ☁链接:点击获取 ⭐频道😮圈子✏投稿🌍中文

祂录lze目录群

@talulze · Post #1851 · 22.08.2024 г., 02:49

电脑解压软件之7-zip 刚是解压南+的一个【资源】的时候,我下的SP51的两个压缩包,【SP51.7z.000】和【SP51.7z.001】,这个000我一直解压不出来(因为教程就让解压000) 于是向朋友求助。他告诉我说bandizip解压这个分压不行,可以试试7-zip,于是我试了试真成了。他说是简便还好用。 7-zip官网【 https://www.7-zip.org/ 】 标签:#解压#压缩包#7zip#7z#win软件#解压软件