TGTGInsighttelegram intelligenceLIVE / telegram public index
← Python Заметки

TGINSIGHT SIMILAR POSTS

Најди сличен содржај

Изворен канал @pythonotes · Post #397 · 12 ное.

Использование Pydantic сегодня стало нормой, и это правильно. Но иногда на ревью вижу, что используют его не всегда корректно. Например, метод BaseModel.model_dump() по умолчанию не преобразует стандартные типы, такие как datetime, UUID или Decimal, в простой сериализуемый для JSON вид. Тогда пишут кастмоный сериализатор для этих типов чтобы функция json.dump() не падала с ошибкой. import uuid from datetime import datetime from decimal import Decimal from uuid import UUID from pydantic import BaseModel class MyModel(BaseModel): id: UUID date: datetime value: Decimal obj = MyModel( id=uuid.uuid4(), date=datetime.now(), value='1.23' ) print(obj.model_dump()) # не подходит для json.dump # { # 'id': UUID('4f8c1bc4-25fd-40cd-9dbe-2c73639b0dc1'), # 'date': datetime.datetime(2025, 12, 12, 12, 12, 12, 111111), # 'value': Decimal('1.23') # } # добавляем свой кастомный сериализатор json.dumps(obj.model_dump(), cls=MySerializer) # { # 'id': '4f8c1bc4-25fd-40cd-9dbe-2c73639b0dc1', # 'date': '2025-12-12T12:12:12.111111', # 'value': '1.23' # } В данном случае класс MySerializer обрабатывает datetime, UUID и Decimal. Например так: class MySerializer(json.JSONEncoder): def default(self, o): if isinstance(o, Decimal): return str(o) elif isinstance(o, datetime): return o.isoformat() elif isinstance(o, UUID): return str(o) return super().default(o) Специально для тех, кто всё еще так делает - в этом нет необходимости! Pydantic может это сделать сам, просто нужно добавить параметр mode="json". json.dumps(obj.model_dump(mode="json")) # { # 'id': '4f8c1bc4-25fd-40cd-9dbe-2c73639b0dc1', # 'date': '2012-12-12T12:12:12.111111', # 'value': '1.23' # } #pydantic#libs

Резултати

Пронајдени 4 слични објави

Пребарај: #onchaintrack

当前筛选 #onchaintrack清除筛选
Data | CryptoAttack 🎅🏼

@cryptoarsenal · Post #62730 · 12.04.2026 г., 16:09

⁠⁠‌‌‌​​‌‌​​​‌​​​‌​‌‌‌‌‌​‌‌‌​‌​‌⁠⁠🔗⚡️#RAVE#ETH RAVE: From 0x2dC2...031B to BITGET (Hot Wallet) Token: RAVEDAO (RAVE) Amount: $9,459,036 (2,983,923) Chain: ETHEREUM TX#Onchaintrack ⏱️ Time (UTC): 15:47:23.345⁠⁠‌‌‌​​‌‌​​​‌​​​‌​‌‌‌‌‌​‌‌‌​‌​‌⁠⁠

Data | CryptoAttack 🎅🏼

@cryptoarsenal · Post #62715 · 12.04.2026 г., 11:48

⁠⁠‌‌‌​​‌‌​​​‌​​​‌​‌‌‌‌‌​‌‌‌​‌​‌⁠⁠🔗⚡️#LIT#ETH LIT: From LIGHTER (ZkLighter (Proxy)) to HTX (Recovery Hot Wallet) Token: LIGHTER (LIT) Amount: $3,934,489 (3,646,422) Chain: ETHEREUM TX#Onchaintrack ⏱️ Time (UTC): 11:38:07.118⁠⁠‌‌‌​​‌‌​​​‌​​​‌​‌‌‌‌‌​‌‌‌​‌​‌⁠⁠

Data | CryptoAttack 🎅🏼

@cryptoarsenal · Post #62977 · 15.04.2026 г., 20:51

⁠⁠‌‌‌​​‌‌​​​‌​​​‌​‌‌‌‌‌​‌‌‌​‌​‌⁠⁠🔗⚡️#WLFI#ETH#BNB WLFI: From 0x0a36...d6f0 to BINANCE (Hot Wallet) Token: WORLD LIBERTY FINANCIAL (WLFI) Amount: $14,954,845 (185,000,000) Chain: ETHEREUM TX#Onchaintrack ⏱️ Time (UTC): 20:43:48.733⁠⁠‌‌‌​​‌‌​​​‌​​​‌​‌‌‌‌‌​‌‌‌​‌​‌⁠⁠

Data | CryptoAttack 🎅🏼

@cryptoarsenal · Post #62780 · 13.04.2026 г., 10:19

⁠⁠‌‌​‌​​‌‌​‌​‌​‌​​‌​‌​​‌​​‌​​​​​​⁠⁠🔗⚡️#RLUSD#ETH#BNB RLUSD: From BINANCE (Hot Wallet) to WINTERMUTE (Hot Wallet) Token: RLUSD (RLUSD) Amount: $1,120,691 (1,120,691) Chain: ETHEREUM TX#Onchaintrack@CryptoAttackBot ⏱️ Time (UTC): 10:19:32.769⁠⁠‌‌​‌​​‌‌​‌​‌​‌​​‌​‌​​‌​​‌​​​​​​⁠⁠