Регулярно требуется преобразовать какой-либо текст в максимально совместимый текст для 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
Prevention: советы нейрохирурга на тему того, как уберечь свой мозг от преждевременного старения
Быть здоровым и полным сил в преклонном возрасте круто, но ясность ума и гибкость мышления важны не менее, а может и даже поболее, чем красота тела. Известный нейрохирург Санджай Гупта рассказывает о лично проверенных приемах, которые позволяют сохранять ему предупреждать преждевременное старение нашего главного органа. Его выводы неудивительны: физическая активность, питание, сон - основа основ в том числе и для мозга.
«Каждый раз, когда я собираюсь сесть, я спрашиваю себя: нужно ли мне сидеть прямо сейчас? В плане пользы движения для мозга это может оказаться гораздо полезнее, чем даже посещение спортзала. У меня в офисе нет стула. Если вы можете стоять или ходить во время встреч, телефонных звонков и других занятий, делайте это. Считайте, что бездействие — это болезнь, а не тренировки — лекарство».
https://theidealist.ru/youngbrain/
#Prevention#человек#здоровье#мозг
Prevention: как научиться запоминать свои сны
Почему мы помним одни сны, а другие ускользают без следа? Всё дело в фазе быстрого сна (REM) — именно в ней происходят почти все сновидения. Но чтобы сон закрепился в памяти, важно проснуться в нужный момент и задержать его в сознании хотя бы на несколько секунд. Особенно хорошо запоминаются кошмары, потому что они часто будят нас резко и надолго. Повысить шансы на «захват» сна можно с помощью регулярного режима, отказа от алкоголя, спокойного пробуждения и ведения дневника. Но главное — это осознанное намерение вспомнить.
«Просто имея намерение запомнить свои сны перед сном, человек может улучшить свою способность к этому».
https://theidealist.ru/remdream/
#Prevention#человек#сны#лайфхак
Prevention: почему Facebook усиливает тревогу — и что происходит, когда из него уходишь
Социальные сети воздействуют на психику не только через контент, но и через саму логику непрерывного эмоционального переключения. Автор описывает личный опыт отказа от Facebook и показывает, как бесконечная лента конфликтов, трагедий и «хороших новостей» перегружает нервную систему, усиливает тревожность и истощает эмпатию. Эксперты объясняют это хаотичным выбросом нейротрансмиттеров и эволюционной неподготовленностью человека к такому объёму социальных связей. Уход из Facebook оказывается не бегством от мира, а способом вернуть ясность, эмоциональный баланс и более человечное отношение к другим.
«Когда мозг наводняют эти противоположные нейротрансмиттеры, мы начинаем чувствовать себя плохо примерно через 15 минут»
https://theidealist.ru/whydeletefacebook/
#Prevention#психология#соцсети#тревожность#ментальноездоровье
Cow Calves Mites Infestation:
*******
#Mite_infestations in calves are usually caused by sarcoptic mange (Sarcoptes scabiei) or
chorioptic mange (Chorioptes bovis).
These mites cause
intense itching,
hair loss,
scabs, and
thickened skin, especially around the
head,
neck,
legs, and
tail base.
#Symptoms of Mite Infestation in Calves:
Severe itching and restlessness
Hair loss and crusty skin lesions
Thickened, wrinkled skin
Reduced weight gain due to stress and discomfort
Secondary bacterial infections if untreated
#Diagnosis:
Skin scrapings examined under a microscope
Clinical signs and response to treatment
#Treatment Options:
1. Topical Treatments:
Lime sulfur dips
Amitraz or permethrin-based sprays
Ivermectin or doramectin pour-on treatments
2. Injectable Treatments:
Ivermectin (SC or oral): Effective against both Sarcoptes and Chorioptes
Doramectin or Moxidectin
3. Environmental Control:
Clean and disinfect calf pens
Avoid overcrowding
Treat all animals in the herd to prevent re-infestation
#Prevention:
Regular parasite control programs
Monitoring new animals for signs of mites
Ensuring good nutrition and overall calf health
https://t.me/starvetbooks