现在的项目中遇到一个问题,项目使用 flask 完成的,现在有几个数据表,有同一个 order 字段,并且都需要对这几个表的数据进行查询和对 order 字段的值进行调整。
低效率的方法是,为这几个表的 Model 类分别实现操作函数,但是这样写出来的代码,几个函数之间只有几个关键字是不一样的,感觉代码很冗余
所以请教大佬们,有什么精简的实现方法呢?
1
PressOne 2018-04-09 16:11:12 +08:00 via Android
你把伪代码贴出来也好分析呀,空对空怎么讲呢
|
2
xpke04 OP 补充一下描述,
``` python def change_docorder(): reqdata = request.json op = reqdata["op"] docid = reqdata["docid"] # 如果是上移文档顺序 if op == "up": another = DocItem.query.filter(and_(DocItem.category_id == docitem.category_id, DocItem.order < docitem.order)).order_by(DocItem.order.desc()).first() if another is None: return error_response(u"无法继续移动该文档顺序!") tmp = another.order another.order = docitem.order docitem.order = tmp another.save() docitem.save() elif op == "down": another = DocItem.query.filter(and_(DocItem.category_id == docitem.category_id, DocItem.order>docitem.order)).order_by(DocItem.order.asc()).first() if another is None: return error_response(u"无法继续移动该文档顺序!") tmp = another.order another.order = docitem.order docitem.order = tmp another.save() docitem.save() else: return make_response(u"非法的操作!") return make_response(json.dumps({ "status": "success", "msg": u"修改文档顺序成功!" })) ``` 这是针对 DocItem 这个 model 进行的调整顺序操作,还有其他的几个 model 对象需要进行相同的操作,如何如果都分别写一个函数来实现功能,最终代码只有类名 `DocItem` 是不一样的。 以上是对问题的补充描述。 |
3
PressOne 2018-04-09 16:26:29 +08:00 via Android
这个你可以写一个闭包方法,把不同的参数传进去就可以,
|
4
xpke04 OP v2ex 贴代码太不方便了,我把问题移至 segmentfault 了, https://segmentfault.com/q/1010000014261968
|