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

Резултати

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

Пребарај: #ogr

当前筛选 #ogr清除筛选

🚀NextUp Hub: University Innovation Challenge🌍 Are you ready to turn your ideas into reality and compete on a national stage? NextUp Hub, powered by the IT Investment Center, is bringing together the brightest minds from universities to tackle the future of technology and business! 💡How it works: 🔹Stage 1 – Universities will hold internal competitions to select the most promising ideas. 🔹Stage 2 – The best teams will compete against other universities in six dynamic fields: 📌Technology & Innovation – AI, Machine Learning, Cybersecurity, IoT, Smart Cities 📌Finance & Digital Economy – Fintech, Blockchain, DeFi, Digital Banking 📌Health & Sustainability – HealthTech, MedTech, Biotech, GreenTech, AgriTech 📌Commerce & Consumer Markets – E-commerce, PropTech, D2C Brands, Gaming 📌Mobility & Space – Logistics, Autonomous Vehicles, SpaceTech, Aerospace 📌Creative Economy & Media – Digital Content, NFT Art, AI-Generated Media, Streaming 🌟Why Join? 🚀 Compete for recognition, mentorship, and investment opportunities 🌍 Get inspired by top global innovation hubs like Station F, We Play, OGR, and AIESEC 🎯 Build your network, gain real-world experience, and turn your vision into reality 🚀How to participate? ✅ Register via Google Form (link in bio) ✅ Get shortlisted and refine your idea ✅ Present your project and compete for top prizes! 📅Don’t miss out! Register now and take the first step toward innovation! #NextUpHub#UniversityInnovation#TechForFuture#StartupChallenge#ITInvestmentCenter#StationF#WePlay#OGR#AIESEC _ 🚀NextUp Hub: Universitet Innovatsion Tanlovi🌍 O‘z g‘oyalaringizni haqiqatga aylantirish va milliy sahnada ishtirok etishga tayyormisiz? NextUp Hub, IT Investment Center ko‘magida universitetlarning eng iqtidorli talabalarini birlashtirib, texnologiya va biznesning kelajagini shakllantirishga chorlaydi! 💡Qanday ishlaydi? 🔹1-bosqich – Universitetlar ichida tanlov o‘tkazilib, eng istiqbolli g‘oyalarni saralab oladi. 🔹2-bosqich – Eng yaxshi jamoalar quyidagi oltita yo‘nalishda boshqa universitetlar bilan bellashadi: 📌Texnologiyalar va innovatsiyalar – Sun’iy intellekt, mashinaviy o‘rganish, kiberxavfsizlik, IoT, aqlli shaharlar 📌Moliya va raqamli iqtisodiyot – Fintech, blockchain, DeFi, raqamli banking 📌Sog‘liqni saqlash va barqaror rivojlanish – HealthTech, MedTech, biotexnologiya, GreenTech, AgriTech 📌Savdo va iste’mol bozorlar – E-commerce, PropTech, D2C brendlar, geyming 📌Harakatlanish va kosmos – Logistika, avtonom transport, SpaceTech, aerokosmik sanoat 📌Kreativ iqtisodiyot va media – Raqamli kontent, NFT san’at, AI-muhandislik, striming 🌟Nega ishtirok etish kerak? 🚀 Tanlovda qatnashib, e’tirof, mentorlik va investitsiya imkoniyatlarini qo‘lga kiriting 🌍Station F, We Play, OGR, AIESEC kabi dunyoning yetakchi innovatsion markazlaridan ilhom oling 🎯 Tarmoq yarating, real tajriba orttiring va g‘oyalaringizni hayotga tatbiq qiling 🚀Qanday ishtirok etish mumkin? ✅ Google Form orqali ro‘yxatdan o‘ting (havola bio da) ✅ Saralashdan o‘tib, g‘oyangizni takomillashtiring ✅ Loyihangizni taqdim etib, eng yaxshi jamoalar qatoriga kirishga harakat qiling! 📅Imkoniyatni qo‘ldan boy bermang! Hoziroq ro‘yxatdan o‘ting va innovatsiyalar sari ilk qadamni tashlang! #NextUpHub#UniversityInnovation#TechForFuture#StartupChallenge#ITInvestmentCenter#StationF#WePlay#OGR#AIESEC