Pydantic :一个数据验证python库 python检验数据类型
off999 2024-12-22 20:09 34 浏览 0 评论
前言
Pydantic 是一个用于数据验证和解析的 Python 库,它通过声明式的方式定义数据模型,并提供了自动生成文档、验证数据等功能。
一.安装
pip install pydantic二.基本用法
1.定义数据模型:
使用 Pydantic 定义数据模型,可以通过继承 pydantic.BaseModel 来创建模型类。在模型类中声明字段并定义它们的类型。
from pydantic import BaseModel
class User(BaseModel):
id: int
username: str
email: str2.实例化和验证:
使用定义的模型类创建实例,并进行数据验证。Pydantic 将验证数据类型和字段的其他规则。
user_data = {"id": 1, "username": "张三", "email": "zs@example.com"}
user = User(**user_data)
print(user)
如果提供的数据与模型不匹配,Pydantic 将引发 pydantic.error_wrappers.ValidationError 异常。
3.模型的字段Field验证:
Pydantic 的 Field 是一个用于定义模型字段的类,它允许你为模型中的每个字段指定类型、默认值、描述以及其他验证规则。以下是 Field 的一些常见用法:
- 定义字段类型:通过 Field 可以明确指定字段的数据类型,确保数据的类型安全。
- 设置默认值:可以在 Field 中为字段设置默认值,当创建模型实例时未提供该字段的值,将使用默认值。
- 添加描述信息:可以为字段添加描述信息,这有助于生成文档或在错误消息中提供更清晰的说明。
- 自定义验证:如果需要对字段进行额外的验证,可以在 Field 中使用 validator 参数来添加自定义的验证函数。
- 字段别名:有时候需要在不同的上下文中使用不同的字段名,可以通过 Field 的 alias 参数来实现。
- 控制序列化:通过 Field 的 exclude 参数,可以控制该字段是否被包含在模型的序列化输出中。
- 读取描述:可以使用 description 属性来获取字段的描述信息,这在自动生成API文档时非常有用。
- 额外信息:Field 还支持 title、example 等其他参数,用于提供更多关于字段的信息。
- 继承和共享:如果多个模型中有相同的字段定义,可以使用 Field 来实现字段的继承和共享,避免重复代码。
- 配合类型注解:Field 通常与 Python 的类型注解一起使用,以提供更强的类型检查和自动完成功能。
from pydantic import BaseModel, Field, ValidationError, field_validator
class User(BaseModel):
id: int = Field(default=0, lt=100, gt=0)
username: str
email: str
if __name__ == '__main__':
user_data = {"id": 120, "username": "张三", "email": "zs@example.com"}
try:
user = User(**user_data)
except ValidationError as e:
print(e.json(indent=4))
4.模型的额外配置
在模型中,可以通过 class Config 类来配置一些行为,例如是否启用数据解析、字段别名、校验字段的预处理函数等。
from pydantic import BaseModel, Field, ValidationError, field_validator
class User(BaseModel):
id: int = Field(default=0, lt=100, gt=0)
username: str
email: str
@field_validator('username')
def name_must_alpha(cls, v):
assert v.isalpha(), 'name must be alpha'
return v
if __name__ == '__main__':
#print(User.model_json_schema())
user_data = {"id": 12, "username": "123", "email": "zs@example.com"}
try:
user = User(**user_data)
except ValidationError as e:
print(e.json(indent=4))5.生成文档:
Pydantic 可以自动生成 API 文档。通过使用 schema() 方法,
from pydantic import BaseModel, Field, ValidationError, field_validator
class User(BaseModel):
id: int = Field(default=0, lt=100, gt=0)
username: str
email: str
@field_validator('username')
def name_must_alpha(cls, v):
assert v.isalpha(), 'name must be alpha'
return v
if __name__ == '__main__':
print(User.model_json_schema()6.注意事项
1.类型注解:确保使用正确的类型提示来定义字段,以便Pydantic能够进行准确的验证。这是Pydantic强大验证功能的基础。
2.数据模型验证:当创建模型实例时,Pydantic会自动根据模型中定义的规则验证传入的数据。如果数据无效,Pydantic将抛出异常并停止验证过程。
3.错误消息:Pydantic提供友好的错误消息,帮助理解验证失败的原因。这有助于调试和用户反馈。
4.环境变量:可以使用BaseSettings从环境变量中读取系统设置,这对于配置管理非常有用。
5.序列化与反序列化:Pydantic支持数据的序列化和反序列化,可以轻松地将数据转换为Python数据结构、JSON等格式。
6.IDE集成:Pydantic与IDE和linter配合良好,可以提供更好的开发体验和代码质量。
7.嵌套模型:在模型内部使用其他模型,以创建复杂的数据结构,同时保持清晰的结构和易于管理。
8.数据转换:Pydantic会尝试将输入数据转换为模型中定义的字段类型,例如将字符串转换为整数或浮点数。
9.避免循环引用:在使用Pydantic时,应避免模型之间的循环引用,这可能会导致验证过程中的问题。
以上只是pydantic的一部分用法,更多用法请参考官方文档
https://docs.pydantic.dev/latest/相关推荐
- itunes下载的固件在哪个位置
-
可以刷机的将手机联入电脑电脑会自动下载符合手机的版本的固件是一样的,都是通过官方固件包来重装系统。操作步骤如下;1.电脑端下载最新版本的itunes,不然重装时可能会造成未知错误。2.iphone...
- 电脑重装系统后没声音(电脑重装系统后没声音怎么解决win7)
-
如果您在电脑重装系统后没有声音,可能是由于以下一些常见问题导致的:1.驱动程序问题:重装系统后,可能需要重新安装声卡驱动程序。您可以从电脑制造商的官方网站或声卡制造商的官方网站上下载并安装最新的声卡驱...
- win10制作系统u盘(制作win10系统优盘)
-
方法一:使用微软官方工具制作u盘工具安装win101、首先电脑浏览器输入“windows10下载”,找到微软官方地址进入,然后选择立即下载工具到电脑上。2、鼠标右键选择以管理员身份运行,同意协议进入下...
- 苹果手机wlan设置在哪(苹果手机 wlan)
-
进入设置->Wi-Fi。如何设置iPhone的WIFI?2.选择Wi-Fi之后,会显示附近能搜索到的所有的Wi-Fi网络。如何设置iPhone的WIFI?3.选中其中网络Wi-F...
- 召唤系统游戏(召唤系统游戏排行)
-
亡灵进化专家:写的很不错了。猪脚可以用金属或骨头帮自己的亡灵进化升级挺有意思的。不过还没写完网游之审判:是英雄无敌类型的。不过写的很牛逼也写完了。推荐看看还有不死传说:虽然不是召唤的,主教是僵尸和吸血...
- w7系统怎么样(电脑w7系统怎么样)
-
有以下几点理由来分析为什么win7受欢迎1、Windows7有望受到企业用户认可微软目前的最大担心是:企业用户认为Windows7性能同Vista相差不大,因此不会出手购买。微软当初发布Vist...
- 无敌系统流小说(无敌系统流的小说)
-
《嫡女之花开富贵》作者:伊人睽睽简介祖父是镇国将军,贵不可言;外公是帝师,才名满天下;父母亲琴瑟和鸣,恩爱无双,无妾室插足;穿越为书香门第的嫡小姐,且无任何庶兄妹,慕兰音认为,她这一生,必将佳期如梦...
-
- 键盘上windows键是哪个键(电脑键盘上windows键是哪个)
-
一、台式机键盘。Windows键,简称“Winkey”或“Win键”,是在计算机键盘左下角Ctrl和Alt键之间的按键,台式机全尺寸键盘的主键盘区左下角和右下角各有一个,图案是MicrosoftWindows的视窗徽标。二、笔记...
-
2026-01-13 11:51 off999
-
- 桌面图标设置在哪打开(桌面图标从哪里调出)
-
1、首先来到电脑桌面,此时桌面没有任何图标,如下图所示。2、我们先右键单击任务栏,会出现工具栏,这时我们在下拉的选项里选择“快速启动”按钮。3、单击快速启动按钮后会出现如图所示情况,这时在电脑屏幕的左下方会显示很多快捷按钮,一般情况下单击快...
-
2026-01-13 10:51 off999
- windows如何进入启动项(怎么进入启动选项)
-
方法步骤如下:1.点击应用在Windows设置界面点击应用选项进入。2.选择启动在左侧分类中选择启动选项。3.点击开关点击软件后方的开关即可启动或关闭开机启动项。1、在Window的文件资...
- win11下载安装
-
一、允许安装软件1、首先点击左下角的开始按键,然后点击“settings”进入设置。2、然后点击设置中的“应用”选项。3、在点击左侧任务栏中的“应用和功能”。4、点击下拉栏,然后选择其中的“任何来源”...
- win7支持的最高配置(win7支持的最高配置是多少)
-
答案是支持win7的最高配置应该是i99900k加b365主板。 不过这套配置市面上价格偏高。这种机器比同等酷睿13代处理器的价格还要高至少一千元以上。而且就性能而言要超过i99900...
- 指令引用的内存不能为read(指令引用的0x0000000内存.该内存不能为read)
-
出现“指令引用内存不能为read”的错误可能有多种原因,包括软件冲突、驱动问题、内存质量问题等。以下是一些可能的解决方案:1.检查是否有软件冲突:尝试关闭可能冲突的软件,例如杀毒软件、优化软件等。2...
- hp1010打印机驱动程序(hp deskjet1010打印机驱动)
-
1.把光盘到电脑里然后打开光盘找到“setup.exe”双击运行。2.这里点击“不用了,谢谢,我喜欢CD安装”;下载的驱动也点这个。3.到这个一步有6个软件需要安装,不用点选直接下一步即可。4.同意服...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
