zoukankan      html  css  js  c++  java
  • python序列化模块json与pickel

     序列化就是将原本的字典、列表等内容转换成一个字符串。

     常用的两个模块是json与pickle.

    Json模块提供了四个功能:dumps、dump、loads、load.

    dumps和loads

    dumps和loads用于序列化字符串,而剩下两个则用于处理到文件句柄。
    
    >>> json.dumps({'aa':2})
    '{"aa": 2}'
    
    
    >>> json.loads('{"aa": 2}')
    {'aa': 2}

    dump和load

    f = open('json_file','w')
    dic = {'k1':'v1','k2':'v2','k3':'v3'}
    json.dump(dic,f)  #dump方法接收一个文件句柄,直接将字典转换成json字符串写入文件
    f.close()
    
    f = open('json_file')
    dic2 = json.load(f)  #load方法接收一个文件句柄,直接将文件中的json字符串转换成数据结构返回
    f.close()
    print(type(dic2),dic2)
    • json,用于字符串 和 python数据类型间进行转
    • 而pickle,用于python特有的类型 和 python的数据类型间进行转换

    pickel更为强大,pickle模块提供了四个功能:dumps、dump(序列化,存)、loads(反序列化,读)、load  (不仅可以序列化字典,列表...可以把python中任意的数据类型序列化)。

    但json是一种所有的语言都可以识别的数据结构。如果我们将一个字典或者序列化成了一个json存在文件里,那么java代码或者js代码也可以拿来用。

    但是如果我们用pickle进行序列化,其他语言就不能读懂这是什么了~

  • 相关阅读:
    [Tensorflow2.0] 入门
    重新开始深度学习
    大秦小记三
    大秦小记二
    大秦小记一
    大秦小记初始篇
    js事件高级
    jsDOM
    css样式
    c#压缩文件和批量压缩文件
  • 原文地址:https://www.cnblogs.com/hercules-chung/p/12383428.html
Copyright © 2011-2022 走看看