• 【6】python的json与字典转换(dump 和dumps load和loads的区别)


     1. json序列化(字典转成字符串)方法:

              dumps:无文件操作            dump:序列化+写入文件

      2. json反序列化(字符串转成字典)方法:

              loads:无文件操作              load: 读文件+反序列化

     1、基本使用

    import json# 导入模块
    d = {'s':'you','d':'are'}   #给一个字典
    j = json.dumps(d)#dumps字典转换成字符串
    print(type(j))
    print(j)
    
    d1 = json.loads(j)#loads字符串转换成字典
    print(type(d1))
    print(d1)
    print(d1.keys())#输出字典的key
    print(d1.values())#输出字典的值
    
    执行后得到的结果:
    <class 'str'>
    {"d": "are", "s": "you"}
    
    <class 'dict'>
    {'d': 'are', 's': 'you'}
    dict_keys(['d', 's'])
    dict_values(['are', 'you'])

    2、json.dumps()

             json.dumps()用于将dict类型的数据转成str,因为如果直接将dict类型的数据写入json文件中会发生报错,因此在将数据写入时需要用到该函数。

    import json
     
    name_emb = {'a':'1111','b':'2222','c':'3333','d':'4444'} 
     
    jsObj = json.dumps(name_emb)    
     
    print(name_emb)
    print(jsObj)
     
    print(type(name_emb))
    print(type(jsObj))

        运行结果如下:

    {'a': '1111', 'c': '3333', 'b': '2222', 'd': '4444'} {"a": "1111", "c": "3333", "b": "2222", "d": "4444"} <type 'dict'> <type 'str'>

    3、json.loads()

              json.loads()用于将str类型的数据转成dict。

    import json
     
    name_emb = {'a':'1111','b':'2222','c':'3333','d':'4444'} 
     
    jsDumps = json.dumps(name_emb)    
     
    jsLoads = json.loads(jsDumps) 
     
    print(name_emb)
    print(jsDumps)
    print(jsLoads)
     
    print(type(name_emb))
    print(type(jsDumps))
    print(type(jsLoads))     

              运行结果如下:

             'a'变成了u'a'是因为发生了类型转换,str会转换成unicode

    {'a': '1111', 'c': '3333', 'b': '2222', 'd': '4444'}
    {"a": "1111", "c": "3333", "b": "2222", "d": "4444"}
    {u'a': u'1111', u'c': u'3333', u'b': u'2222', u'd': u'4444'}
    <type 'dict'>
    <type 'str'>
    <type 'dict'>

    4、json.dump() 

            json.dump()用于将dict类型的数据转成str,并写入到json文件中。下面两种方法都可以将数据写入json文件

    import json  
      
    name_emb = {'a':'1111','b':'2222','c':'3333','d':'4444'}  
              
    emb_filename = ('/home/cqh/faceData/emb_json.json')  
     
    # 方法 1
    jsObj = json.dumps(name_emb)    
    with open(emb_filename, "w") as f:  
        f.write(jsObj)  
        f.close()  
        
    # 方法 2   
    json.dump(name_emb, open(emb_filename, "w"))

    5、json.load()

              json.load()用于从json文件中读取数据。

    import json  
     
    emb_filename = ('/home/cqh/faceData/emb_json.json')  
     
    jsObj = json.load(open(emb_filename))    
     
    print(jsObj)
    print(type(jsObj))
     
    for key in jsObj.keys():
        print('key: %s   value: %s' % (key,jsObj.get(key)))

    运行结果如下:

    {u'a': u'1111', u'c': u'3333', u'b': u'2222', u'd': u'4444'}
    <type 'dict'>
    key: a   value: 1111
    key: c   value: 3333
    key: b   value: 2222
    key: d   value: 4444
  • 相关阅读:
    Ubuntu上使用Latex
    Ubuntu18.04 解压文件名乱码的解决方法
    Android 编译 opencv
    android 使用编译好的sdk
    https协议加密原理介绍(一)
    java 面试题目 class.forName和load的区别
    给进程设置环境变量
    Maven 编译jdk配置
    Docker积累
    潜谈单例模式
  • 原文地址:https://www.cnblogs.com/haifeima/p/9595553.html
Copyright © 2020-2023  润新知