flask_restful自定义序列化规则

在使用flask_restful进行开发类视图函数的时候,需要自定义序列化规则。
两种方式:


class Coo(fields.Raw):
    def format(self, start_time):
        """重写format函数,将时间返回改成:年-月"""
        time_ = start_time.strftime('%Y-%m')
        return time_


fields = {  # 序列化规则
    'username': fields.String(attribute='name'), # 指定对应的模型属性
    'age': fields.Integer(default=10),  # 设置默认值
    'height': fields.Float,
    'scores': fields.List(fields.Integer), 
    # 方案一:自定义类规则
    'start_time': Coo(attribute='start_time'),  #Coo类为自定义的序列化规则
    # 方案二:在attribute属性中自定义规则
    'start_time': fields.String(attribute=lambda t:t.start_time.strftime('%Y-%m') if t.start_time else None),

}


class DemoResource(Resource):
    method_decorators = {'post': [marshal_with(fields)]}
    def post(self):
        user1 = User()
        # 如果设置了marshal_with装饰器, 可以直接返回模型对象
        return user1


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flask-RESTful 中,可以使用 request_parser 来预处理 POST 请求中的 JSON 数据。使用 request_parser 可以在处理 JSON 数据之前对数据进行验证和预处理,以确保数据的有效性。以下是一个使用 request_parser 预处理 JSON 数据的示例: ``` from flask import Flask, request from flask_restful import Api, Resource, reqparse app = Flask(__name__) api = Api(app) parser = reqparse.RequestParser() parser.add_argument('name', type=str, required=True, help='Name is required') parser.add_argument('age', type=int, required=True, help='Age is required') class User(Resource): def post(self): args = parser.parse_args() name = args['name'] age = args['age'] # perform validation and pre-processing on the data here # ... # return the response return {'name': name, 'age': age} api.add_resource(User, '/user') if __name__ == '__main__': app.run(debug=True) ``` 在上面的示例中,我们首先创建了一个 RequestParser 对象,然后使用 add_argument 方法添加需要解析的参数。接下来,在 User 类的 post 方法中,我们使用 parser.parse_args() 方法解析 POST 请求中的 JSON 数据,并从解析结果中获取 name 和 age 参数。我们可以在获取参数之后对数据进行验证和预处理,完成后再返回响应。 需要注意的是,Flask-RESTful 会自动将返回值序列化为 JSON 格式,并设置 Content-Type 头为 application/json。因此,在返回响应时,只需要返回一个 Python 字典即可,无需手动进行 JSON 序列化

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值