使用棉花糖的 JSON 序列化 - 跳过无属性

Tom*_*eif 3 serialization json python-3.x marshmallow

我正在使用 Marshmallow 将我的 Decision 类的实例发送到 JSON。但是,这也将转储属性None,例如,我的属性score将转换为nullJSON。之后,我无法使用相同的方法再次读取 JSON。

https://repl.it/repls/VolluminousMulticoloredFacts

最后一行是它当前失败的地方。我需要在加载过程中不转储None到 JSON 或跳过null

import json
from marshmallow import Schema, fields, post_load

json_data = """{
    "appid": "2309wfjwef",
    "strategy": "First Strategy"
}"""

# Output class definition
class Decision(object):
    def __init__(self, appid = None, strategy = None, score = None):
        self.appid = appid
        self.strategy = strategy
        self.score = score

class DecisionSchema(Schema):
    appid = fields.Str()
    strategy = fields.Str()
    score = fields.Int()

    @post_load
    def make_decision(self, data):
        return Decision(**data)

# Deserialization into object
dec_json = json.loads(json_data)
schema = DecisionSchema()
dec = schema.load(dec_json).data

print(dec.strategy)

# Dump results back to JSON
schema = DecisionSchema()
out = schema.dumps(dec)

print(out.data)

# Load back from dump
schema = DecisionSchema()
dec = schema.load(out).data

#print(dec.strategy) # returns error currently
Run Code Online (Sandbox Code Playgroud)

Jér*_*ôme 5

棉花糖开发团队的“官方”回答可以在 bugtracker 的这个评论中找到:

使用一种post_dump方法。

from marshmallow import Schema, fields, post_dump

class BaseSchema(Schema):
    SKIP_VALUES = set([None])

    @post_dump
    def remove_skip_values(self, data, **kwargs):
        return {
            key: value for key, value in data.items()
            if value not in self.SKIP_VALUES
        }


class MySchema(BaseSchema):
    foo = fields.Field()
    bar = fields.Field()


sch = MySchema()
sch.dump({'foo': 42, 'bar': None}).data  # {'foo': 42}
Run Code Online (Sandbox Code Playgroud)

正如我在进一步评论中指出的那样,有一个缺点:None当字段allow_none为时,它也会删除True