每日学习--JSON

本文探讨了如何处理Tensor类型在尝试通过json.dumps转换为字符串时遇到的问题,提出将Tensor转换为str或将数据持久化为pickle。介绍了json和pickle的序列化功能区别以及在实际操作中的应用案例。
摘要由CSDN通过智能技术生成

问题:Object of type Tensor is not JSON serializable

    json_str = json.dumps(image_dict)
    with open('../yy/Data/weibo/image_dict.json', 'w') as json_file:
        json_file.write(json_str)

原因:json.dumps函数发现字典里面有bytes类型的数据,无法编码。
解决方法:将bytes类型的数据转化成str类型;或者用pickle
【我字典里存的图片对应的tensor用不了json.dumps转换成字符串,只能强制转换】

    # json_str = json.dumps(image_dict)
    with open('../yy/Data/weibo/image_dict.json', 'w') as json_file:
        json_file.write(str(image_dict))

补充
在这里插入图片描述

json和pickle是用于序列化的两个模块,都有四个功能:
dumps、dump、loads、load

jsonpickle
dumps、dump、loads、loaddumps、dump、loads、load
用于字符串和python数据类型间进行转换于python特有的类型和python的数据类型间进行转换
可以在不同语言之间交换数据只在python之间使用
只能序列化最基本的数据类型[(列表、字典、列表、字符串、数字)]可以序列化所有的数据类型,包括类,函数、日期

1. dumps 数据–>字符串

import json

test_dict = {'bigberg': [7600, {1: [['iPhone', 6300], ['Bike', 800], ['shirt', 300]]}]}
print(test_dict)
print(type(test_dict))
#dumps 将数据转换成字符串
json_str = json.dumps(test_dict)
print(json_str)
print(type(json_str))

在这里插入图片描述

2.dump: 将数据–>json文件

with open("../config/record.json","w") as f:
	json.dump(new_dict,f)
    print("加载入文件完成...")

在这里插入图片描述

3.loads: 字符串–>字典

new_dict = json.loads(json_str)
print(new_dict)
print(type(new_dict))

4.load:打开文件并把字符串–>数据类型

with open("../config/record.json",'r') as load_f:
    load_dict = json.load(load_f)
    print(load_dict)
load_dict['smallberg'] = [8200,{1:[['Python',81],['shirt',300]]}]
print(load_dict)

with open("../config/record.json","w") as dump_f:
    json.dump(load_dict,dump_f)

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值