打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
pydantic学习与使用-12.使用 Field 定制字段

前言

Field 可用于提供有关字段和验证的额外信息,如设置必填项和可选,设置最大值和最小值,字符串长度等限制

Field模块

关于 Field 字段参数说明

  • Field(None) 是可选字段,不传的时候值默认为None

  • Field(…) 是设置必填项字段

  • title 自定义标题,如果没有默认就是字段属性的值

  • description 定义字段描述内容

from pydantic import BaseModel, Field

class Item(BaseModel):
name: str
description: str = Field(None,
title="The description of the item",
max_length=10)
price: float = Field(...,
gt=0,
description="The price must be greater than zero")
tax: float = None

a = Item(name="yo yo",
price=22.0,
tax=0.9)
print(a.dict()) # {'name': 'yo yo', 'description': None, 'price': 22.0, 'tax': 0.9}

schema_json

title 和 description 在 schema_json 输出的时候可以看到

print(Item.schema_json(indent=2))

"""
{
"title": "Item",
"type": "object",
"properties": {
"name": {
"title": "Name",
"type": "string"
},
"description": {
"title": "The description of the item",
"maxLength": 10,
"type": "string"
},
"price": {
"title": "Price",
"description": "The price must be greater than zero",
"exclusiveMinimum": 0,
"type": "number"
},
"tax": {
"title": "Tax",
"type": "number"
}
},
"required": [
"name",
"price"
]
}
"""

Field 相关参数

Field可用于提供有关字段和验证的额外信息。

参数名称描述
default(位置参数)字段的默认值。由于Field替换了字段的默认值,因此第一个参数可用于设置默认值。使用省略号 ( …) 表示该字段为必填项。
default_factory当该字段需要默认值时将被调用。除其他目的外,这可用于设置动态默认值。禁止同时设置default和default_factory。
alias字段的别名
description文档字符串
exclude在转储(.dict和.json)实例时排除此字段
include在转储(.dict和.json)实例时(仅)包含此字段
const此参数必须与字段的默认值相同(如果存在)
gt对于数值 ( int, float, ),向 JSON SchemaDecimal添加“大于”的验证和注释exclusiveMinimum
ge对于数值,这将添加“大于或等于”的验证和minimumJSON 模式的注释
lt对于数值,这会为exclusiveMaximumJSON Schema添加“小于”的验证和注释
le对于数值,这将添加“小于或等于”的验证和maximumJSON 模式的注释
multiple_of对于数值,这会multipleOf向 JSON Schema添加“多个”的验证和注释
max_digits对于Decimal值,这将添加验证以在小数点内具有最大位数。它不包括小数点前的零或尾随的小数零。
decimal_places对于Decimal值,这增加了一个验证,最多允许小数位数。它不包括尾随十进制零。
min_itemsminItems对于列表值,这会向 JSON Schema添加相应的验证和注释
max_itemsmaxItems对于列表值,这会向 JSON Schema添加相应的验证和注释
unique_itemsuniqueItems对于列表值,这会向 JSON Schema添加相应的验证和注释
min_lengthminLength对于字符串值,这会向 JSON Schema添加相应的验证和注释
max_lengthmaxLength对于字符串值,这会向 JSON Schema添加相应的验证和注释
allow_mutation一个布尔值,默认为True. TypeError当为 False 时,如果在实例上分配了字段,则该字段引发 a 。模型配置必须设置validate_assignment为True执行此检查。
regex对于字符串值,这会添加从传递的字符串生成的正则表达式验证和patternJSON 模式的注释
repr一个布尔值,默认为True. 当为 False 时,该字段应从对象表示中隐藏。
**任何其他关键字参数(例如examples)将逐字添加到字段的架构中
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Pydantic 初学者指南
深入浅出FlatBuffers原理
Mysql查询字段中包含某字符串的记录
MySQL常用的SQL语句//输出所有信息showfullfieldsfrom'表名称';//改表
ThinkJS 中数据解析和校验
Spring认证中国教育管理中心-Spring Data Couchbase教程二
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服