[Python] Marshmallow QuickStart
常用小操作索引
- 指定fields必须:
fields.String(required=True)
- 部分loading:
- 不load name:
result = UserSchema.load({'email': 'mail@mail.com'}, partail=('name',)
- 只load email:
result = UserSchema.load({'email': 'mail@mail.com'}, partail=True
- 不load name:
只读/只写:
fields.Str(load_only=True)
fields.Str(dump_only=True)
排序输出: 返回一个OrderedDict
class UserSchema(Schema):
...
class Meta:
fields=('name', 'email') # 输出顺序
ordered=True
声明Schema
from marshmallow import Schema, fields
class UserSchema(Schema):
name = fields.Str()
email = fields.Email()
created_at = fields.DateTime()
序列化对象('Dumping')
即将Python对象格式化为通用格式数据输出 dump方法返回namedtuple, dumps方法返回一个json string
from marshmallow import pprint
user = User(name="Monty", email="monty@ptyhon.org")
schema = UserSchema()
result = schema.dump(user)
pprint(result)
只dump部分字段:
schema = UserSchema(only=('name', 'email'))
对象反序列化('Loading')
即将通用数据格式化为Python对象输入 通过post_load修饰器将数据格式化为对象
from marshmallow import Schema, fields, post_load
class UserSchema(Schema):
name = fields.Str()
email = fields.Email()
created_on = fields.DateTime()
@post_load
def make_user(self, data):
return User(**data)
对数据调用load方法,会返回User对象
data = {'name': 'test', 'email': 'mail@mail.com'}
schema = UserSchema()
result = schema.load(data)
resutl # => user对象 <User(name='test')>
同时处理多个对象/数据 (many=True)
指定many参数:Schema(many=True)
user1 = User(...)
user2 = User(...)
users = [user1, user2]
schema = UserSchema(many=True)
result = schema.dump(users, many=True) # load方法也类似
数据校验
当输入外部数据时, 使用Schema.load()方法。如果数据与定义Schema时的规则不一致,则raise ValidationError
.
ValidationError.messages
: 错误信息ValidationError.valid_data
: 符合规则的,正确解析的数据
err message 和valid_data的格式如下:
from marshmallow import ValidationError
try:
result = UserSchema().load({'name': 'John', 'email': 'foo'})
except ValidationError as err:
err.messages # => {'email': ['"foo" is not a valid email address.']}
valid_data = err.valid_data # => {'name': 'John'}
自定义校验函数
在定义Schema的时候, 指定validate参数。validate支持function, lambda 或含call定义的对象。
以上面的UserSchema为例:
def email_validate(email):
name, domain = email.split('@')
if domain != 'mail.com':
raise ValidationError('不支持非mail.com邮箱注册')
class UserSchema(Schema):
...
email = fields.Email(validate=email_validate)
这里的validte并不会覆盖掉内置的fields.Email的校验。如果有多个validate规则,使用list/tuple/generator输入。
自定义校验函数在外部调用
即validator
from marshmallow import fields, Schema, validates, ValidationError
class UserSchema(Schema):
...
email = fields.Email()
@validates('email')
def email_validate(self, email):
name, domain = email.split('@')
if domain != 'mail.com':
raise ValidationError('不支持非mail.com邮箱注册')
return True
这样就可以单独在外部做邮箱验证,比如:is_email_valid = UserSchema.email_validate('mail@mail.com')
然而验证了一下,这种validator会覆盖掉本身带的fields.Email()检验。按上面的方法,'mail,/www@mail.com'这样的无效邮箱也时返回True的
load数据时,不明Fields的处理 => stable版本不包含,lastest版本包含
- EXLUDE: 忽略不明fields数据
- INCLUDE: 接受不明fields数据
- RAISE: 抛出ValidationError
marshmallow默认会忽略不明fields数据 指定方式:
在Meta Class中指定
class UserSchema(Schema):
...
class Meta:
unknown = INCLUDE
- 实例化时指定:
schema = UserSchema(unknown=EXLUDE)
- 调用load时才指定:
UserSchema().load(data, unknown=RAISE)
[Python] Marshmallow QuickStart的更多相关文章
- [Python]Marshmallow 代码
schema.dump和schema.load schema.dump()方法返回一个MarshResult的对象,marshmallow官方API说dump和load方法返回的都是dict对象,但查 ...
- Beam编程系列之Python SDK Quickstart(官网的推荐步骤)
不多说,直接上干货! https://beam.apache.org/get-started/quickstart-py/ Beam编程系列之Java SDK Quickstart(官网的推荐步骤)
- [Python] 学习资料汇总
Python是一种面向对象的解释性的计算机程序设计语言,也是一种功能强大且完善的通用型语言,已经有十多年的发展历史,成熟且稳定.Python 具有脚本语言中最丰富和强大的类库,足以支持绝大多数日常应用 ...
- Python学习资料下载地址(转)
[转]Python学习资料和教程pdf 开发工具: Python语言集成开发环境 Wingware WingIDE Professional v3.2.12 Python语言集成开发环境 Wingwa ...
- [转]Python学习资料和教程pdf
开发工具: Python语言集成开发环境 Wingware WingIDE Professional v3.2.12 Python语言集成开发环境 Wingware WingIDE Professio ...
- 转:Python语言编程学习资料(电子书+视频教程)下载汇总
开发工具: Python语言集成开发环境 Wingware WingIDE Professional v3.2.12 Python语言集成开发环境 Wingware WingIDE Professio ...
- grpc python quickstart
参考:grpc python quickstart 准备 1.升级pip $ python -m pip install --upgrade pip 2.安装grpc $ python -m pip ...
- marshmallow: 简化Python对象系列化
转载:http://www.thinksaas.cn/topics/0/594/594368.html marshmallow -一个轻量级的库用于将复杂对象转成简单的Python数据类型.或从简单的 ...
- Python(二)Marshmallow 库相关学习
0. 前言 Marshmallow 是一个用于将 ORM 对象与 Python 原生数据类型之间转换的库.实现 object → dict.object → list.string → dict 和 ...
随机推荐
- 小学生都看得懂的C语言入门(5): 指针
现在已经学到C语言的后面了, 快学完咯.... (一)取地址运算 先来看一下sizeof 计算所占字节 #include<stdio.h> int main() { int a; a=; ...
- CF558E
非常好的一道题,是线段树的常见玩法 将字符串转化为1~26个数 对区间开一棵线段树,用两个数组分别维护区间中1~26每个数的个数以及一个区间覆盖标记,表示这个区间是否被某一个值覆盖了 在每次排序时,首 ...
- jQuery常见的几个文档处理方式
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- 备份还原数据数据库(固定IP版)
1.新建data文件夹,用于存放备份数据 2.新建db文件夹,用于存放初建数据库为脚本 3.首次使用双击export.bat进行备份数据库: 4.以后每次使用双击setup.bat进行还原数据库: 备 ...
- mysql的innodb存储引擎
innodb是支持事务的存储引擎,支持ACID特性的ACID(指数据库事务正确执行的四个基本要素的缩写) 包含:原子性(Atomicity).一致性(Consistency).隔离性(Isolatio ...
- Junit4 IDEA测试学习一
1.Junit4 下载 https://github.com/junit-team/junit4/releases 4.12 还需要还导入hamcrest-core-1.3.jar 2.IDEA Te ...
- innobackupex做MySQL增量备份及恢复
http://www.cnblogs.com/paul8339/p/6731688.html
- python之requests 乱七八糟
1.预配置 import requests ss = requests.Session() ss.headers.update({'user-agent':'Mozilla/5.0 (Windows ...
- python全栈开发day87~91-整个流程梳理、CRM功能、知识点梳理
1.流程 1. stark组件 1. 启动 2.注册 3.url设计 4.视图函数设计 1.展示数据头 2.展示数据 3.list_display功能实现 4.list_display_links 功 ...
- 关于SQL Server中的系统表之一 sysobjects
微软Sql Server数据库是企业开发管理中最常用的数据库系统之一.其功能强大而且使用简单.方便.我们在数据库中创建数据库.表.视图.触发器.存储过程.函数等信息. 最常用的功能之一,查询数据,例如 ...