首先,我对python和flask是个新手。我到处寻找,尝试了一些无用的东西。我有一个模型,它的成员之一是DateTimeField,我们称它为"created_at“。当我将查询集作为JSON返回时,我在字段中看到如下内容
...
"created_at": {
"$date": 1412938697488
}
...
有没有办法获得输出,或者通过自定义的JSON编码器,等等,让它看起来像这样:
"created_at": "2014-10-10T07:33:04Z",
任何指导或建议都将不胜感激。
谢谢!
发布于 2021-01-13 13:42:09
以下是使用flask和flask-mongoengine获取ISO 8601字符串形式的日期的示例
import datetime
from bson.json_util import dumps
from flask import Flask, Response, request
from flask_mongoengine import MongoEngine
app = Flask(__name__)
db = MongoEngine()
class Movie(db.Document):
name = db.StringField(required=True, unique=True)
casts = db.ListField(db.StringField(), required=True)
genres = db.ListField(db.StringField(), required=True)
created_at = db.DateTimeField(default=datetime.datetime.utcnow)
@app.route('/movies')
def get_movies():
movies = Movie.objects()
movies_list = []
for movie in movies:
movie_dict = movie.to_mongo().to_dict()
movie_dict['created_at'] = movie.created_at.isoformat()
movies_list.append(movie_dict)
movies_josn = dumps(movies_list)
return Response(movies_josn, mimetype="application/json", status=200)
@app.route('/movies', methods=['POST'])
def add_movie():
body = request.get_json()
movie = Movie(**body).save()
id = movie.id
return {'id': str(id)}, 200
if __name__ == '__main__':
app.config['MONGODB_SETTINGS'] = {
'host': 'mongodb://localhost/movie-bag'
}
db.init_app(app)
app.run()
https://stackoverflow.com/questions/26307439
复制