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

Пребарај: #dito

当前筛选 #dito清除筛选
VPS自留地

@zx_vps · Post #2043 · 18.10.2025 г., 09:59

#菲律宾#eSIM#DITO 🇵🇭DITO eSIM 菲律宾第三大电信运营商 DITO 由 菲律宾 DITO CME 公司与中国电信集团 共同组成,是菲律宾第三大电信运营商,支持 eSIM 并可在中国大陆漫游。 📶功能与特点: • 支持 中国移动 4G 漫游 • WiFi Calling:安卓无需 VPN 秒连;iOS 需 VPN 辅助 • 支持 iMessage 与 +63 号段(10位数) • eSIM 可联网删除后重新扫描原二维码恢复 💰中国大陆漫游资费: • 拨打电话:₱35 ≈ ¥4.29 / 分钟 • 接听电话:₱35 ≈ ¥4.29 / 分钟 • 发短信:₱15 ≈ ¥1.84 / 条 • 收短信:免费 • 流量:需另购数据套餐 🔒实名认证与保号方式: 写入eSIM后登录APP:选"Register my DITO number",然后选"菲律宾个人",用护照+人脸+谷歌地地址 秒过 充值 ₱5(约 ¥0.62)即可延长号码有效期 1 年(不可叠加) 📱DITO 官方 App Store 下载 🔘@TossIPhone🔘@TossIChannel

东南亚出境攻略

@boguaguacn · Post #220 · 07.11.2024 г., 02:28

#菲律宾#手机卡#GLOBE#Smart#DITO DITO SIM、 SIM Smart 卡有效期(2024年11月5日更新) 1.以下是 DITO SIM 卡过期并永久断开(卡自动注销)的情形整理: 未激活或未使用:如果 SIM 卡在包装信封上注明的有效期之前未激活且未使用,则会过期并永久断开。 一年内无活动:若已激活的 SIM 卡在自上次 DITO 预付费充值之日起一年内没有任何活动,SIM 卡将过期并永久断开。 低于 1 PHP余额后无活动:如果已激活的 SIM 卡在达到小于 1 PHP余额后,您订阅的套餐将暂时断开。一旦充值,您订阅的套餐将重新激活。如果暂时断开状态持续 90 天或更长时间,您订阅的套餐将被永久断开,您的 DITO SIM 卡将被永久禁用,您的 DITO 手机号码将被封锁并列入黑名单。 注意事项: DITO 不负责更换任何永久断开和列入黑名单的 SIM 卡,且此类 SIM 卡无法重新连接至 DITO 网络,关联的手机号码不会被重新分配。 永久断开的 SIM 卡中残余的任何 DITO 预付费充值不可兑换或退还现金。 2.以下是 Smart SIM 卡过期并永久断开(卡自动注销)的情形整理: 未激活或未使用:如果 SIM 卡在包装信封上注明的有效期之前未激活且未使用,则会过期并永久断开。 一年内无活动:若已激活的 SIM 卡在自上次 Smart 预付费充值之日起一年内没有任何活动,SIM 卡将过期并永久断开。 零余额后无活动:如果已激活的 SIM 卡在达到零余额或零余额促销到期后的 180 天内没有任何活动,SIM 卡将过期并永久断开。 注意事项: Smart 不负责更换任何永久断开的 SIM 卡,且此类 SIM 卡无法重新连接至 Smart 网络,关联的手机号码可能会被重新分配。 永久断开的 SIM 卡中残余的任何 Smart 预付费充值不可兑换或退还现金。 TNT SIM 或其他 Smart 旗下sim卡均以此为准 💫投稿热线:@coocooASD@Ada19889 💰投稿爆料最高20U