@ragagazzetta · Post #231146 · 11.04.2026 г., 14:48
r/ #technology Умная гитара без струн изГонконга Инструмент Lava Genie от стартапа Lava Music считывает взмахи рукой и постукивания пальцами, переводя их в музыку.
Hashtags
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
Пребарај: #technology
@ragagazzetta · Post #231146 · 11.04.2026 г., 14:48
r/ #technology Умная гитара без струн изГонконга Инструмент Lava Genie от стартапа Lava Music считывает взмахи рукой и постукивания пальцами, переводя их в музыку.
Hashtags
@googlefactss · Post #40304 · 12.12.2025 г., 07:04
The first hard disk drive to reach the 1-gigabyte (GB) capacity weighed approximately 227-250 kgs (500 - 550 pounds) for the main unit. This device, the IBM 3380 direct access storage device, was announced by IBM in 1980. It was roughly the size of a refrigerator and carried a price tag of approximately $40,000. @googlefactss#technology
Hashtags
@googlefactss · Post #40297 · 11.12.2025 г., 07:04
The first website ever is still online and accessed at a restored CERN address: http://info.cern.ch. While the original site is gone, a 1992 copy of the page is available, which describes the World Wide Web project, its technical details, and how to use it. @googlefactss#technology
Hashtags
@googlefactss · Post #40294 · 10.12.2025 г., 19:05
Email has been around longer than the World Wide Web. The first email was sent by Ray Tomlinson to himself in 1971, a good 20 years before Tim Berners-Lee introduced the web in 1991. @googlefactss#technology [read more...]
Hashtags
@googlefactss · Post #40274 · 07.12.2025 г., 23:01
The internet is estimated to weigh about 50 grams, equivalent to a strawberry, based on the weight of the electrons used in electricity for data transfer. This does not account for the much larger physical weight of servers, cables, and data centers that support its infrastructure. @googlefactss#technology [read more....]
Hashtags
@droneswar · Post #9590 · 07.12.2024 г., 12:35
r/ #technology Грустная история на вечер: в Северной Калифорнии робот пылесос пытается найти свой дом после землетрясения Видимо, он отключился от своей базы во время стихии, а теперь потерялся.
Hashtags
@droneswar · Post #9479 · 21.10.2024 г., 15:51
r/ #technology Будущие космические роботы уже здесь Эти самоорганизующиеся роботы GITAI потенциально могут построить будущую инфраструктуру на Марсе и за его пределами. Скорость не так важна в космосе. Но выполнение работы и работа имеют первостепенное значение.
Hashtags
@dailychannels · Post #6703 · 23.02.2026 г., 01:00
Channel: Hustlers News Members: ~4.55K 💢 Username: @hustlers_news Description: Channel dedicated to post news. Official site: www.hustlers.ly 🏷 Tags: #technology https://lve.to/pvphboywru
Hashtags
@dailychannels · Post #6524 · 05.12.2025 г., 01:00
Channel: AI Post — Artificial Intelligence news Members: ~992.41K 💢 Username: @aipost Description: The #1 AI news source! We cover the latest artificial intelligence breakthroughs and emerging trends. Contact: @CaptainJamesCook 🏷 Tags: #technology https://telegramchannels.me/channels/aipost
Hashtags
@dailychannels · Post #6468 · 07.11.2025 г., 13:00
Channel: benedict cumberTech Members: ~1.27M 💢 Username: @cumbertech Description: ️the most valuable from the world of technologies, AI, crypto and innovational science buy ads: @cumberAds or https://telega.io/c/cumbertech 🏷 Tags: #technology https://telegramchannels.me/channels/cumbertech
Hashtags
@dailychannels · Post #6429 · 21.10.2025 г., 01:00
Channel: Analytics and growth mindset ️ Members: ~7.75K 💢 Username: @thinkbroadly Description: Free data analytics courses with certificates, hot internships and jobs - everything that needed data analyst. Buy ads: @maria_v2022 🏷 Tags: #technology https://telegramchannels.me/channels/thinkbroadly
Hashtags
@dailychannels · Post #6402 · 09.10.2025 г., 13:00
Channel: UXLINK Members: ~331.36K 💢 Username: @uxlink_community Description: UXLINK official channel 🏷 Tags: #technology https://telegramchannels.me/channels/uxlink_community
Hashtags