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 слични објави

Пребарај: #udca

当前筛选 #udca清除筛选
Libertà è ragione

@libertaeragione · Post #3905 · 24.07.2023 г., 14:39

#Elezioni#Spagna Risultati definitivi: Affluenza: 70,4% (+4,2 rispetto al 2019) #PP|EPP: 33,05% #PSOE|S&D: 31,7% #VOX|ECR: 12,39% #Sumar (#IU-#Podemos-#MP-#eQuo-#AV-#Compromís)|LEFT|G/EFA: 12,31% #ERC|G/EFA: 1,89% #Junts|NI: 1,6% #EHBildu|LEFT: 1,36% #PNV|RE: 1,12% #PACMA|LEFT: 0,67% #BNG|G/EFA: 0,62% #CC|RE: 0,46% #CUP|Sinistra catalana separatista: 0,4% #UPN|Centro-destra navarro unionista: 0,21% #FO|Sinistra euroscettica sovranista: 0,19% #NC|G/EFA: 0,18% #EV/#TE|Localisti: 0,15% #PDeCAT-#CiU|Centro-destra catalano indipendentista: 0,12% #RC|Sinistra: 0,09% #UPL|Centro Leonese: 0,09% #PUMJ|Ecologisti europeisti: 0,09% #PCTE|INITIATIVE: 0,07% #GBai|Centro-sinistra navarro indipendentista: 0,04% #AA|Sinistra andalusa: 0,03% #EB|Voto di protesta: 0,03% #JMM|Regionalisti di Jaén: 0,03% #XAV|Centro regionalista di Ávila: 0,02% #BQEx|Centro-sinistra federalista extremegno: 0,02% #CJ|Sincretici anti-establishment: 0,02% #FEJONS|Estrema destra: 0,02% #PAR|Centro-destra aragonese autonomista: 0,01% #PH|Umanisti: 0,01% #PMR|Centro-destra murciano regionalista: 0,01% #AC-#UP-#PCPC|Sinistra canaria indipendentista: 0,01% #CpM|Centro-sinistra musulmano: 0,01% #PREPAL|Leonesisti: 0,01% #UdCa|Conservatori castigliani regionalisti: 0,01% #CCD|Centro suarista: 0,01% @OsservatorioEsteri