最近想把数据库查询出来转换成对象,发现Python没有Java中fastjson这种很方便的库(目前我不知道,hh)
所以通过自带json的loads()、dumps()方法实现了一下
class changeObject():
def __init__(self, data=None):
if data:
self.__dict__ = data
def select(self, sql):
dba = MysqLUtils.DBUtil()
dba.get_con();
dba.cursor.execute(sql)
index = dba.cursor.description # 存储表头信息
# print(index)
result = []
for res in dba.cursor.fetchall():
row = {}
for i in range(0, len(index)):
row[index[i][0]] = res[i]
result.append(row)
dba.cursor.close()
return result
def changeObject(self, result):
objectList = []
for res in result:
# jsonstr = json.dumps(res,ensure_ascii=False)
jsonstr = json.dumps(res, ensure_ascii=False, default=str)
jsondict = json.loads(jsonstr, object_hook=changeObject)
objectList.append(jsondict)
return objectList
重点就是搞清楚 loads(),是将json数据转换为dict数据,dumps()将dict数据转换为json数据
object_hook的参数为对应类,它其实就是修改类的__dict__属性,把参数赋值上去,也许这就是动态语言的优势吧!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。