El parámetro include de Pydantic, pasado a los modelos de Pydantic para
establecer los campos a incluir.
TYPE:IncEx | NoneDEFAULT:None
exclude
El parámetro exclude de Pydantic, pasado a los modelos de Pydantic para
establecer los campos a excluir.
TYPE:IncEx | NoneDEFAULT:None
by_alias
El parámetro by_alias de Pydantic, pasado a los modelos de Pydantic para
definir si la salida debería usar los nombres alias (cuando se proporcionan) o
los nombres de atributos de Python. En una API, si estableces un alias,
es probablemente porque quieres usarlo en el resultado, así que probablemente
quieras dejar esto establecido en True.
TYPE:boolDEFAULT:True
exclude_unset
El parámetro exclude_unset de Pydantic, pasado a los modelos de Pydantic
para definir si debería excluir de la salida los campos que no fueron
establecidos explícitamente (y que solo tenían sus valores por defecto).
TYPE:boolDEFAULT:False
exclude_defaults
El parámetro exclude_defaults de Pydantic, pasado a los modelos de Pydantic
para definir si debería excluir de la salida los campos que tenían el mismo
valor por defecto, incluso cuando fueron establecidos explícitamente.
TYPE:boolDEFAULT:False
exclude_none
El parámetro exclude_none de Pydantic, pasado a los modelos de Pydantic para
definir si debería excluir de la salida cualquier campo que tenga un valor
None.
TYPE:boolDEFAULT:False
custom_encoder
El parámetro custom_encoder de Pydantic, pasado a los modelos de Pydantic
para definir un codificador personalizado.
Excluye de la salida cualquier campo que comience con el nombre _sa.
Esto es principalmente un truco para compatibilidad con objetos de SQLAlchemy,
almacenan estado interno específico de SQLAlchemy en atributos nombrados con
_sa, y esos objetos no pueden (y no deberían) ser serializados a JSON.
TYPE:boolDEFAULT:True
Código fuente en fastapi/encoders.py
defjsonable_encoder(obj:Annotated[Any,Doc(""" The input object to convert to JSON. """),],include:Annotated[IncEx|None,Doc(""" Pydantic's `include` parameter, passed to Pydantic models to set the fields to include. """),]=None,exclude:Annotated[IncEx|None,Doc(""" Pydantic's `exclude` parameter, passed to Pydantic models to set the fields to exclude. """),]=None,by_alias:Annotated[bool,Doc(""" Pydantic's `by_alias` parameter, passed to Pydantic models to define if the output should use the alias names (when provided) or the Python attribute names. In an API, if you set an alias, it's probably because you want to use it in the result, so you probably want to leave this set to `True`. """),]=True,exclude_unset:Annotated[bool,Doc(""" Pydantic's `exclude_unset` parameter, passed to Pydantic models to define if it should exclude from the output the fields that were not explicitly set (and that only had their default values). """),]=False,exclude_defaults:Annotated[bool,Doc(""" Pydantic's `exclude_defaults` parameter, passed to Pydantic models to define if it should exclude from the output the fields that had the same default value, even when they were explicitly set. """),]=False,exclude_none:Annotated[bool,Doc(""" Pydantic's `exclude_none` parameter, passed to Pydantic models to define if it should exclude from the output any fields that have a `None` value. """),]=False,custom_encoder:Annotated[dict[Any,Callable[[Any],Any]]|None,Doc(""" Pydantic's `custom_encoder` parameter, passed to Pydantic models to define a custom encoder. """),]=None,sqlalchemy_safe:Annotated[bool,Doc(""" Exclude from the output any fields that start with the name `_sa`. This is mainly a hack for compatibility with SQLAlchemy objects, they store internal SQLAlchemy-specific state in attributes named with `_sa`, and those objects can't (and shouldn't be) serialized to JSON. """),]=True,)->Any:""" Convert any object to something that can be encoded in JSON. This is used internally by FastAPI to make sure anything you return can be encoded as JSON before it is sent to the client. You can also use it yourself, for example to convert objects before saving them in a database that supports only JSON. Read more about it in the [FastAPI docs for JSON Compatible Encoder](https://fastapi.tiangolo.com/tutorial/encoder/). """custom_encoder=custom_encoderor{}ifcustom_encoder:iftype(obj)incustom_encoder:returncustom_encoder[type(obj)](obj)else:forencoder_type,encoder_instanceincustom_encoder.items():ifisinstance(obj,encoder_type):returnencoder_instance(obj)ifincludeisnotNoneandnotisinstance(include,(set,dict)):include=set(include)# type: ignore[assignment] # ty: ignore[invalid-assignment]ifexcludeisnotNoneandnotisinstance(exclude,(set,dict)):exclude=set(exclude)# type: ignore[assignment] # ty: ignore[invalid-assignment]ifisinstance(obj,BaseModel):obj_dict=obj.model_dump(mode="json",include=include,exclude=exclude,by_alias=by_alias,exclude_unset=exclude_unset,exclude_none=exclude_none,exclude_defaults=exclude_defaults,)returnjsonable_encoder(obj_dict,exclude_none=exclude_none,exclude_defaults=exclude_defaults,sqlalchemy_safe=sqlalchemy_safe,)ifdataclasses.is_dataclass(obj):assertnotisinstance(obj,type)obj_dict=dataclasses.asdict(obj)returnjsonable_encoder(obj_dict,include=include,exclude=exclude,by_alias=by_alias,exclude_unset=exclude_unset,exclude_defaults=exclude_defaults,exclude_none=exclude_none,custom_encoder=custom_encoder,sqlalchemy_safe=sqlalchemy_safe,)ifisinstance(obj,Enum):returnobj.valueifisinstance(obj,PurePath):returnstr(obj)ifisinstance(obj,(str,int,float,type(None))):returnobjifisinstance(obj,PydanticUndefinedType):returnNoneifisinstance(obj,dict):encoded_dict={}allowed_keys=set(obj.keys())ifincludeisnotNone:allowed_keys&=set(include)ifexcludeisnotNone:allowed_keys-=set(exclude)forkey,valueinobj.items():if((notsqlalchemy_safeor(notisinstance(key,str))or(notkey.startswith("_sa")))and(valueisnotNoneornotexclude_none)andkeyinallowed_keys):encoded_key=jsonable_encoder(key,by_alias=by_alias,exclude_unset=exclude_unset,exclude_none=exclude_none,custom_encoder=custom_encoder,sqlalchemy_safe=sqlalchemy_safe,)encoded_value=jsonable_encoder(value,by_alias=by_alias,exclude_unset=exclude_unset,exclude_none=exclude_none,custom_encoder=custom_encoder,sqlalchemy_safe=sqlalchemy_safe,)encoded_dict[encoded_key]=encoded_valuereturnencoded_dictifisinstance(obj,(list,set,frozenset,GeneratorType,tuple,deque)):encoded_list=[]foriteminobj:encoded_list.append(jsonable_encoder(item,include=include,exclude=exclude,by_alias=by_alias,exclude_unset=exclude_unset,exclude_defaults=exclude_defaults,exclude_none=exclude_none,custom_encoder=custom_encoder,sqlalchemy_safe=sqlalchemy_safe,))returnencoded_listiftype(obj)inENCODERS_BY_TYPE:returnENCODERS_BY_TYPE[type(obj)](obj)forencoder,classes_tupleinencoders_by_class_tuples.items():ifisinstance(obj,classes_tuple):returnencoder(obj)ifis_pydantic_v1_model_instance(obj):raisePydanticV1NotSupportedError("pydantic.v1 models are no longer supported by FastAPI."f" Please update the model {obj!r}.")try:data=dict(obj)exceptExceptionase:errors:list[Exception]=[]errors.append(e)try:data=vars(obj)exceptExceptionase:errors.append(e)raiseValueError(errors)fromereturnjsonable_encoder(data,include=include,exclude=exclude,by_alias=by_alias,exclude_unset=exclude_unset,exclude_defaults=exclude_defaults,exclude_none=exclude_none,custom_encoder=custom_encoder,sqlalchemy_safe=sqlalchemy_safe,)