python中dump 和dumps load和loads的区别

关于这两者的区别自己一开始记得住但是过了一段时间就容易忘记,所以写一篇博客来记录一下。此文章为转载的文章,因为写的比较细,所以特此写一篇博客:

地址:https://blog.csdn.net/mr_evanchen/article/details/77879967

1、json.dumps()

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

[python] view plain copy

  1. import json  
  2.    
  3. name_emb = {'a':'1111','b':'2222','c':'3333','d':'4444'}   
  4.   
  5. jsObj = json.dumps(name_emb)      
  6.   
  7. print(name_emb)  
  8. print(jsObj)  
  9.   
  10. print(type(name_emb))  
  11. print(type(jsObj))  

          运行结果如下:

[python] view plain copy

  1. {'a''1111''c''3333''b''2222''d''4444'}  
  2. {"a""1111""c""3333""b""2222""d""4444"}  
  3. <type 'dict'>  
  4. <type 'str'>  

           若在数据写入json文件时,未先进行转换,报错如下

[python] view plain copy

  1. import json    
  2.     
  3. name_emb = {'a':'1111','b':'2222','c':'3333','d':'4444'}    
  4.             
  5. emb_filename = ('/home/cqh/faceData/emb_json.json')    
  6.     
  7. # jsObj = json.dumps(name_emb)      
  8.     
  9. with open(emb_filename, "w") as f:    
  10.     f.write(name_emb)    
  11.     f.close()    

           转换后再写入,则不报错

 2、json.loads()

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

[python] view plain copy

  1. import json  
  2.    
  3. name_emb = {'a':'1111','b':'2222','c':'3333','d':'4444'}   
  4.   
  5. jsDumps = json.dumps(name_emb)      
  6.   
  7. jsLoads = json.loads(jsDumps)   
  8.   
  9. print(name_emb)  
  10. print(jsDumps)  
  11. print(jsLoads)  
  12.   
  13. print(type(name_emb))  
  14. print(type(jsDumps))  
  15. print(type(jsLoads))       

          运行结果如下:

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

[python] view plain copy

  1. {'a''1111''c''3333''b''2222''d''4444'}  
  2. {"a""1111""c""3333""b""2222""d""4444"}  
  3. {u'a': u'1111', u'c': u'3333', u'b': u'2222', u'd': u'4444'}  
  4. <type 'dict'>  
  5. <type 'str'>  
  6. <type 'dict'>  

 3、json.dump()

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

[python] view plain copy

  1. import json    
  2.     
  3. name_emb = {'a':'1111','b':'2222','c':'3333','d':'4444'}    
  4.             
  5. emb_filename = ('/home/cqh/faceData/emb_json.json')    
  6.   
  7. # solution 1  
  8. jsObj = json.dumps(name_emb)      
  9. with open(emb_filename, "w") as f:    
  10.     f.write(jsObj)    
  11.     f.close()    
  12.       
  13. # solution 2     
  14. json.dump(name_emb, open(emb_filename, "w"))  

          运行结果如下:

  4、json.load()

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

[python] view plain copy

  1. import json    
  2.   
  3. emb_filename = ('/home/cqh/faceData/emb_json.json')    
  4.   
  5. jsObj = json.load(open(emb_filename))      
  6.   
  7. print(jsObj)  
  8. print(type(jsObj))  
  9.   
  10. for key in jsObj.keys():  
  11.     print('key: %s   value: %s' % (key,jsObj.get(key)))  

 运行结果如下:

[python] view plain copy

  1. {u'a': u'1111', u'c': u'3333', u'b': u'2222', u'd': u'4444'}  
  2. <type 'dict'>  
  3. key: a   value: 1111  
  4. key: c   value: 3333  
  5. key: b   value: 2222  
  6. key: d   value: 4444  

  • 35
    点赞
  • 99
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不过如此1951

如果有收获,可以打赏一下

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值