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