У строки в Python есть два очень похожих метода. На столько похожих что кажется они делают одно и тоже.
Это метод isdigit() и isnumeric()
Давайте посмотрим зачем нам два одинаковых метода? И так ли они одинаковы?
Очевидно что isdigit() говорит нам, состоит ли строка только из чисел 0-9
>>> '12'.isdigit()
True
>>> '12x'.isdigit()
False
>>> '-12'.isdigit()
False
>>> '12.5'.isdigit()
False
Можно предположить что isnumeric() делает более глубокий анализ и распознаёт в строке float или отрицательное число.
>>> '15'.isnumeric()
True
>>> '-15'.isnumeric()
False
>>> '15.2'.isnumeric()
False
Нет, всё так же как и с другим методом. В чем же тогда разница? Для начала посмотрим следующие примеры:
>>> '5'.isdigit(), '5'.isnumeric() # Обычная цифра 5
# True, True
>>> '꧕'.isdigit(), '꧕'.isnumeric() # Яванская 5
# True, True
>>> '෩'.isdigit(), '෩'.isnumeric() # Синхала 3
# True, True
>>> '৩'.isdigit(), '৩'.isnumeric() # Бенгальская 3
# True, True
>>> '༣'.isdigit(), '༣'.isnumeric() # Тибетская 3
# True, True
>>> '³'.isdigit(), '³'.isnumeric() # 3 верхний индекс (степень)
# True, True
>>> '𝟝'.isdigit(), '𝟝'.isnumeric() # Математическая двойная 5
# True, True
>>> '๔'.isdigit(), '๔'.isnumeric() # Тайская 4
# True, True
>>> '➑'.isdigit(), '➑'.isnumeric() # 8 в круге
# True, True
А теперь примеры в которых, по мнению Python, результаты не равны
>>> '¾'.isdigit(), '¾'.isnumeric() # дробь три четверти
# False, True
>>> '⅕'.isdigit(), '⅕'.isnumeric() # дробь одна пятая
# False, True
>>> '𒐶'.isdigit(), '𒐶'.isnumeric() # клинопись 3
# False, True
>>> '三'.isdigit(), '三'.isnumeric() # 3 из унифицированной идеограммы
# False, True
>>> '⑩'.isdigit(), '⑩'.isnumeric() # цифра 10 в круге
# False, True
>>> 'Ⅳ'.isdigit(), 'Ⅳ'.isnumeric() # Римская 4
# False, True
>>> '𑇪'.isdigit(), '𑇪'.isnumeric() # Сенегальская архаическая 10
# False, True
>>> '𐌢'.isdigit(), '𐌢'.isnumeric() # Этрусская цифра 10
# False, True
>>> 'ↂ'.isdigit(), 'ↂ'.isnumeric() # Римская цифра 10000
# False, True
>>> '〇'.isdigit(), '〇'.isnumeric() # Символ ККЯ ноль
# False, True
Получается, что isdigit() говорит нам, является ли символ десятичной цифрой или спецсимволом, имеющим цифирное значение после преобразования.
В свою очередь isnumeric() включает все дополнительные символы юникода которые имеют отношения к числовым и цифровым представлениям.
Ну и пара примеров в которых в обоих случаях символ не является числом, это эмодзи.
>>> '🕙'.isdigit(), '🕙'.isnumeric() # эмодзи 10 часов
# False, False
>>> '7️⃣'.isdigit(), '7️⃣'.isnumeric() # эмодзи 7
# False, False
Также есть еще один дополнительный и весьма полезный метод isdecimal().
Он нам сообщает, можно ли из указанного символа сделать простую десятичную цифру. То есть сработает ли метод int(x)
>>> '෩'.isdecimal(), int('෩') # Синхала 3
# True, 3
>>> '➑'.isdecimal(), int('➑') # 8 в круге
# False, ValueError
Какие выводы?
🔸 При определении цифры в строке isdigit() подходит лучше чем isnumeric(), но оба не гарантируют успешную конвертацию в int
🔸 Для однозначного определения возможности преобразования строки в int лучше подходит метод isdecimal()
🔸 Для однозначного определения символов 0...9 лучше использовать regex
Полный список символов юникода которые определяются как numeric
#basic
🎧⤴
TON Blockchain Faces Heat: 500,000 New Wallets Created, But DOGS Token Causes Chaos!
The TON blockchain recently experienced a significant disruption following the airdrop of the DOGS memecoin, which led to the creation of over 500,000 new wallets. Despite this surge, the price of Toncoin (TON) remained stable, although the network faced a three-hour outage due to unprecedented congestion. The TON Foundation quickly addressed the issue, ensuring no loss of user funds, and the network has since recovered. The DOGS token has become a top gainer, with a 21.80% increase in value, highlighting its rising popularity despite the technical hiccups.
Verse 1:
TON got hit with a storm, no block, just pause,
500K new wallets, but they ain't break no laws,
DOGS dropped hard, crashed the chain with a cause,
Validators lost the rhythm, but we back with no loss.
Chorus:
DOGS on the rise, TON had to pay,
But no coin lost, we still in the game,
From Paris to the chain, Durov's fight ain’t lame,
Network's back strong, ain't nobody to blame.
Verse 2:
From Binance to Bybit, exchanges felt the strain,
Suspended withdrawals, but TON ain't in vain,
67K per second, transactions hit the lane,
Yet Toncoin stands tall, pushing through the pain.
Chorus:
DOGS on the rise, TON had to pay,
But no coin lost, we still in the game,
From Paris to the chain, Durov's fight ain’t lame,
Network's back strong, ain't nobody to blame.
Bridge:
DOGS flying high, memecoin of the day,
TON's resilience showed, come what may,
Validators sync up, no more delay,
Crypto's wild ride, just another day.
Verse 3:
TON shook but didn’t fall, learned from the past,
500K wallets, this storm won’t last,
DOGS might bark loud, but TON's built to blast,
New blocks, new hopes, we rising fast.
Chorus:
DOGS on the rise, TON had to pay,
But no coin lost, we still in the game,
From Paris to the chain, Durov's fight ain’t lame,
Network's back strong, ain't nobody to blame.
#TONwallet
#DOGS
#Ton
🎧@toncoin_rap
🚀Обновление экосистемы MirraCoin: новые возможности на DigitalExchange.art и в Mirra Wallet😎
Экосистема MirraCoin продолжает активно развиваться. Мы внедрили ряд важных обновлений и улучшений на платформе DigitalExchange.art и в Mirra Wallet, направленных на удобство, безопасность и расширение функционала для пользователей.
🖼 Обновления на DigitalExchange.art
🔂 Повышена безопасность - поддержка Google Authenticator для 2FA и возможность включить проверку при отправке транзакций.
🔂 Расширена загрузка изображений - теперь при добавлении товара можно прикрепить до 20 изображений вместо прежних 5.
🔂 NFT-копии - добавлено пояснение через информационную кнопку, чтобы пользователи лучше понимали назначение этого инструмента.
🔂 Новая система верификации пользователей - реализована двухуровневая логика выбора:
• Верификация продавца (18+)
• «Благотворительность – дети» благотворительное направление для детей с разделением по возрасту.
🔂 Реализована система поддержки всех продавцов, через пожертвования в криптовалюте: 1 ❤️ => 1 😎
🔂 Обновлена система уведомлений - уведомления теперь приходят как внутри платформы, так и на email пользователя.
🔂 Обновлена главная страница - добавлены новости, раздел "Маркетплейс", отображение балансов.
🔂 Добавлены кошельки - теперь пользователь видит свой баланс в MIRRC, в ₽, в USDT, BTC. Скоро будет добавлен кошелек в EUR и USD.
🔂 Доработан интерфейс - обновлён дизайн и добавлены информационные подсказки для более удобной навигации.
🆕Обновление Mirra Wallet
🔂
Подключение TON Wallet - мы интегрировали возможность прямой конвертации TON=>MIRRC, а также возможность прямой оплаты товаров и пакетов MIRRC за TON.
🔂
Добавили в раздел "Магазин" вкладку "Маркетплейс" - теперь попасть из приложения
Mirra Wallet
на
DigitalExchange.art
возможно в один клик.
🔂
Добавили в раздел "Майнинг" новый буст 500 MIRRC за 1 TON.
🌳 Экосистема MirraCoin продолжает развивать инфраструктуру Web3 и создавать удобные инструменты для пользователей
👉Переходите на платформу, изучайте новые функции и пользуетесь обновлёнными возможностями экосистемы.
👉Подписывайтесь на канал, присоединяйтесь и станьте частью экосистемы MirraCoin, следите за новостями, скоро мы опубликуем о новых разработках и обновлениях.
#MirraCoin#MIRRC#DigitalExchangeArt#MirraWallet#Web3#Blockchain#NFT#Crypto#TonWallet#интеграция#Обновление#Экосистема#Сделано_в_России
@MirraChannel😎