Регулярно требуется преобразовать какой-либо текст в максимально совместимый текст для 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
📕💬ВЫРАВНИВАНИЕ НА ПОСАДКЕ | LANDING FLARE
💬Выравнивание - это переходная фаза между прямолинейным равномерным снижением и непосредственным касанием с поверхностью посадочной полосы. При выравнивании вертикальная скорость снижения практически уменьшается до нуля.
🔹Выравнивание производится путем:
- отклонения ручки управления ВС на себя - тем самым происходит увеличение угла атаки самолёта, приводящего к созданию дополнительной подъемной силы, (уменьшается вертикальная скорость ВС) и увеличению силы лобового сопротивления (уменьшается скорость ВС);
- уменьшения мощности/тяги двигателей (тем самым уменьшается скорость ВС)
🔹В процессе выполнения выравнивания пилот изменяет и корректирует тангаж и мощность СУ по сравнению с теми, которые сохранялись во время окончательного захода на посадку, до значений, подходящих для выполнения нормальной посадки на нужных вертикальной и поступательной скоростях.
🔹Если выравнивание было выполнено правильно, то ВС достигнет подходящего посадочного положения с мощностью на холостом ходу (iDLE THRUST), уменьшающейся поступательной скоростью и уменьшенной вертикальной скоростью снижения. И все это к высоте, которая варьируется от нескольких десятков сантиметров до нескольких футов над поверхностью ВПП.
🔹Если выравнивание было выполнено неправильно например после начала выравнивания оттолкнуть штурвал от себя , то это может привести к довольно неприятным, а то и опасным последствиям, таким как : жесткая посадка, "козление", разрушение стоек шасси, удару хвостом (Tail strike) или вылетом за пределы ВПП.
🔹Как только основные стойки шасси коснулись ВПП, переднюю стойку необходимо опустить мягко и без задержки, т.к. быстрое уменьшение поступательной скорости приведет к уменьшению скорости обтекания руля высоты и как следствие уменьшению его эффективности, что может привести к сильному удару передней стойки о полосу и её повреждению. При этом не откладывайте торможение на конец полосы, и выпускайте реверс сразу же после касания самолета о полосу, т.к. располагаемая длина ВПП ограничена.
🔹Выравнивание на посадке выполняется на критическом этапе полета и, за исключением выполнения автоматической посадки (autoland), зависит от опыта и навыков пилотирующего. Последствия неправильного выравнивания различны и могут быть как незначительными, так и катастрофическими.
Лёгкое небо
#flare#aviation#landing
#powershell#flare#malware_analysis#reverse_engineering
FLARE-VM lets you quickly set up a full reverse engineering and malware analysis environment on a Windows 10+ virtual machine using simple scripts with Chocolatey and Boxstarter. Prepare a VM with 60GB disk, 2GB RAM, no spaces in username, internet, disabled Windows Updates, Tamper Protection, and anti-malware; then run the installer.ps1 script as admin after downloading it. This saves you hours of manual tool installs like IDA Free, Ghidra, and Binary Ninja, giving a ready-to-use, snapshot-revertible lab to safely analyze threats and boost your cybersecurity work.
https://github.com/mandiant/flare-vm
Strongest X-Class Solar Flare in 2.5 Months Recorded
Russian Academy of Sciences solar observatories detected the most powerful X-class solar flare in 2.5 months, accompanied by a major plasma ejection. Scientists predict minimal impact on Earth, with only a slight chance of contact with the plasma cloud’s edge. Solar activity remains high, with more significant events expected today.
“No signs of declining activity are observed at the moment.”
#Sun#Space#Flare#Science#RAS
The main news of Russia and the world ishere.
🚀 Flare Proposes Governance Changes to Capture MEV and Reduce FLR Inflation
Flare has introduced a governance proposal aimed at capturing Maximum Extractable Value (MEV) at the protocol level and reducing the annual inflation rate of its native token, FLR, from 5% to 3%. According to NS3.AI, the proposal outlines a plan to redirect captured revenue and other protocol fees into the FIRE mechanism, which will facilitate open-market buybacks and burns of FLR tokens upon approval. This initiative is designed to enhance the token's value and stability by decreasing inflation and utilizing MEV capture strategically.
#Flare#Governance#MEV#FLR#Crypto#Blockchain#Inflation#Tokenomics#Buyback#Burn