最近想把数据库查询出来转换成对象,发现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__属性,把参数赋值上去,也许这就是动态语言的优势吧!