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

Резултати

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

Пребарај: #dreams

当前筛选 #dreams清除筛选
DGN

@DansGN · Post #5116 · 12.04.2023 г., 14:50

Media Molecule 宣布将于9月1日起停止对《Dreams》的在线支持(live support)。玩家依然可以继续创作,分享,游玩游戏内容,但 Media Molecule 将不会再为游戏提供内容更新或举办相关活动。更多细则请查阅原文 https://docs.indreams.me/en-US/whats-happening/news/dreams-support-update #Dreams

Hashtags

Quiet World 🍁

@QuietWorld · Post #7618 · 04.10.2020 г., 15:34

Rereading my Uncommon Dream Log ✨ It's worth writing & it's worth taking time to look up & interpret the meaning. Been writing only the uncommon ones. One each year since 2018. ✨ 31st Dec 2018 – Phoenix ✨ 2nd Sep 2019 – Four Lions ✨ 29 Sep 2020 – A pair of baby tortoises & a pair of goldfishes with arowana's colour Anyone here have uncommon dream log? 🙋‍♀ #thoughts#justme#dreams @qw_qwbot@quietworld🍃

NEWS 鏈新聞-ABMedia

@abmedia_news · Post #24419 · 07.05.2026 г., 03:30

【🤖 AI人工智慧|Anthropic 推 Claude Dreams:Agent 在工作之間自整理記憶、消除重複與矛盾】 #AI記憶#Anthropic#Dreams Anthropic 於 5 月 6 日推出 Dreams,讓 Agent 具備自主整理記憶的能力。 該技術讀取百個 session 紀錄,並透過 beta header 支援指令輸入。這將記憶管理抽象化,實踐 Agent 隨使用效能不墜的技術目標。 📍閱讀全文: https://abmedia.io/anthropic-claude-dreams-managed-agents-research-preview-may-2026 📍 訂閱鏈新聞頻道:https://linktr.ee/abmedia.io

Luna Everly

@lunaeverly · Post #87 · 18.02.2026 г., 08:04

Stopped by my friend's place today✨ She has a whole studio! 🎮 Streaming chair, cool lights, microphone — it almost made me want to try too. What do you think, would I make a good streamer? Or better leave it to the pros? 😄 #LunaEverly#Streamer#Friend#Idea#Dreams

Notes I Never Shared 🌱

@notesinevershared · Post #69 · 28.08.2025 г., 19:20

🔄🇺🇿 #15 — 4 Kun ichida 3 ish taklifi: Hayotimdagi yangi bosqich Oradan 4 kun o‘tgach, men topshirgan Birlashgan Arab Amirliklaridagi kompaniyalardan menga qo‘ng‘iroq bo’ldi. Ular intervyu o‘tkazishdi. Tez orada 3 ta ish taklifini oldim. Qanday ish deb qiziqayotgan bo‘lsangiz, offitsiant (waiter)— bu ishga kirish va ketish uchun eng oson yo‘llardan biri. Bu jarayon menga sabr, qat’iyat va Allohga tavakkul qilishning ahamiyatini yana bir bor eslatdi. Harakat qilmasdan, faqat orzu qilish bilan hech narsaga erishib bo‘lmaydi. Har bir qadam, har bir qaror — bu yangi imkoniyatlarga yo‘l ochadi. 🔄🇬🇧 #15 — 3 Job Offers in 4 Days: A New Chapter Begins Just three days later, I received a call from the companies I had applied to in the United Arab Emirates. They conducted an interview, and soon after, I received three job offers. Curious about the role? It's a waiter position — one of the easiest entry points into the job market there. This experience reminded me of the importance of patience, determination, and placing trust in Allah. Simply dreaming without taking action leads nowhere. Every step, every decision opens doors to new opportunities. #EverythingILived#TrustInAllah#Action#Dua#Dreams#Dubai#NewChapter