Регулярно требуется преобразовать какой-либо текст в максимально совместимый текст для 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
How to Create a Wallet for BulCoin (BLC)
BulCoin (BLC) operates on the TON network.
To receive BLC, you need a TON wallet.
The most convenient option is MyTonWallet.
⸻
Step 1. Installation
Go to the official website:
https://mytonwallet.io
Available:
• as a browser extension
• as a mobile application
⸻
Step 2. Creating a Wallet
1️⃣ Click "Create Wallet"
2️⃣ Write down the seed phrase (24 words)
3️⃣ Save it offline
4️⃣ Confirm the phrase
⚠️ Never share your seed phrase.
⸻
Step 3. Getting the Address
1️⃣ Open the wallet
2️⃣ Click "Receive"
3️⃣ Copy the TON address
This address is needed to receive BLC.
⸻
We will be announcing a distribution for the first BulCoin participants soon.
Get ready in advance…
#wallet
FAQ | BUY
How to create a wallet for BulCoin (BLC)
BulCoin (BLC) operates on the TON network.
To receive BLC, you need a TON wallet.
The most convenient option is MyTonWallet.
⸻
Step 1. Installation
Go to the official website:
https://mytonwallet.io
Available:
• as a browser extension
• as a mobile application
⸻
Step 2. Creating a Wallet
1️⃣ Click “Create Wallet”
2️⃣ Write down the seed phrase (24 words)
3️⃣ Save it offline
4️⃣ Confirm the phrase
⚠️ Never share your seed phrase.
⸻
Step 3. Getting the address
1️⃣ Open the wallet
2️⃣ Click “Receive”
3️⃣ Copy the TON address
This address is needed to receive BLC.
⸻
In the near future, we will announce a distribution for the first participants of BulCoin.
Prepare in advance…
#wallet
FAQ | BUY
TON Community: Earn with Tokenized Gold
#TON#wallet
TON Community shares how users can earn up to 5% annual yield by holding tokenized gold XAUt0 in the TON Wallet. The process involves using the @affluentappbot Gold Multiply Vault, with daily compounded rewards.
Source: link
@tonlines
⚡️Toncoin: TON Wallet Launches in the USA
#TON#Wallet
Toncoin announces the launch of its TON Wallet in the USA, allowing users to send, gift, or earn money seamlessly within their chat conversations.
Source: link
@tonlines
⚡️TON Society: Zero-Fee Trading on TON Tokens
#TON#Wallet
TON Society announces that Wallet users can trade TON blockchain tokens without any fees until April 14. This is a great opportunity for traders to explore the “Trade” section and manage their investments.
Source: link
@tonlines
Trending Apps: Join the Gift Fest for a Chance to Win Big
#Telegram#Wallet
Trending Apps channel invites users to participate in the Gift Fest, where a $400,000 prize pool will be raffled on December 29. Prizes include iPhones, AirPods, and more, with chances increased by completing tasks and inviting friends.
Source: link
@tonlines
#крипто#wallet
Криптовалютные кошельки
Это приложения или устройства для хранения, отправки и получения цифровых активов. Они хранят приватные ключи пользователей и предоставляют интерфейс для взаимодействия с одним или несколькими блокчейнами.
Криптокошельки можно разделить на виды:
• в зависимости от вовлеченности третьей стороны — на кастодиальные и некастодиальные;
• в зависимости от подключения к интернету — на холодные и горячие.
Кастодиальные кошельки — сервисы, владельцы которых имеют доступ к средствам и приватным ключам пользователей. Если клиент забудет пароль, то его можно будет восстановить с помощью личных данных.
Кастодиальные кошельки - сервисы, владельцы которых самостоятельно управляют средствами и приватными ключами и несут полную ответственность за сохранность средств. ❗️При потере приватного ключа получить доступ к активам невозможно.
Горячие кошельки — приложения и расширения для браузеров, которые постоянно подключены к интернету.
Холодные кошельки — различные способы хранения приватного ключа без доступа к интернету:
• brainwallet — придется запомнить seed-фразу;
• бумажные кошельки — открытый и закрытый ключ распечатываются и хранятся на бумаге;
• аппаратные кошельки — используются специальные устройства, типа флешки.
@MirraChannel😎
⚡️Wallet News: German Language Support Added
#Wallet#crypto
Wallet News has announced the addition of German language support, enhancing accessibility for its users. This update is available in the settings as Wallet Language.
Source: link
@tonlines
#крипто#wallet#биткоин
Что такое bitcoin-only кошельки?
Вы уже знаете, что такое криптовалютные кошельки. С ростом объемов крипторынка, провайдеры стремятся добавить максимальное количество сетей в каждый кошелек, но если вы планируете инвестировать только в первую криптовалюту, стоит выбирать кошельки bitcoin-only ✅.
🔥Преимущества:
• меньше кода - ниже вероятность потенциальных атак.
• простой интерфейс - легче в использовании.
• поддержка новых форматов адресов - более низкие комиссии за транзакции.
💡Самые популярные типы биткоин-кошельков - аппаратные, т.е. физические устройства, которые хранят приватные ключи офлайн. Для взаимодействия с блокчейном пользователи подключаются к компьютеру/смартфону через USB/NFC-соединение или передают PSBT-транзакции (частично подписанные) с помощью SD-карты/QR-кодов.
💡 Наиболее популярные устройства - Coldcard, Jade, Trezor, Bitbox.
@MirraChannel😎
#крипто#wallet#база
Что такое кастодиальный кошелёк?
Это такой кошелёк, где секретные ключи пользователя хранит третья сторона (например, биржа). Владелец кастодиального кошелька может отправлять и получать платежи, но не управляет ключами.
Кастодиальный кошелёк отличается удобством и простотой. Для доступа достаточно ввести имя пользователя и пароль.
❗️ Однако, хранение закрытых ключей третьей стороной и онлайн-характер этих кошельков повышают их уязвимость к кибератакам. Кроме того, существует риск потери средств из-за конфискации государством, если кастодиальной службе грозит банкротство.
🟢Плюсы:
• Меньшая ответственность за безопасность.
• Отсутствие комиссий за транзакции в экосистеме провайдера.
• Доступ можно легко восстановить.
• Доступность на всех устройствах и в браузерах.
🔴Минусы:
• Передача контроля над вашими средствами третьей стороне.
• Необходимость проверки KYC.
• Риски кибератаки.
• Отсутствует возможность автономного использования.
@MirraChannel😎