Python序列化、反序列化

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

上一篇:json 的loads、dumps和jsonpath 的应用


下一篇:JSON序列化