json序列化

数据库必须保存规范的数据
文件只能存字符串和二进制,不能放别的东西
import json
f.write(json.dumps())将各种数据对象转化为str(序列化)
json.loads(f.read)反序列化,将str转为各种数据对象
方便能储存去文本里
json是各种语言通用的,只能进行简单的转换,for example:list tuple ……
json越来越取代了xml

import pickle
方法用的一样的
将各种数据类型转化为bytes数据类型
pickle可以序列化所有内容,不过不一定可以反序列化所有内容
但是pickle只能在python使用
pickle.dump("",f)
pickle.load(f)
理论上来说是允许dump有很有次
但是实际上,只dump一次,只load一次
如果需要dumpn次,请放在不同的文件下
pickle.dump时还有协议上的问题,首先是list时好像要使用-1(复数表示最高级),字典应使用0

dumps只是转换为json字符串
dump要将字符串写入文件
loads也不不牵扯文件操作
load是需要文件操作的

### JSON序列化方法与示例 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。在编程中,JSON序列化是指将对象转换为JSON字符串的过程[^1]。 以下是Python中使用`json`模块进行序列化的示例: ```python import json # 定义一个字典对象 data = { "name": "Alice", "age": 25, "is_student": False, "courses": ["Math", "Science"] } # 将字典对象序列化JSON字符串 json_string = json.dumps(data, indent=4) print(json_string) ``` 上述代码展示了如何将一个Python字典对象转换为JSON字符串。`json.dumps`方法用于将Python对象转换为JSON格式的字符串,参数`indent`用于指定缩进空格数以美化输出[^2]。 如果需要将JSON字符串写入文件,可以使用以下代码: ```python with open("data.json", "w") as file: json.dump(data, file, indent=4) ``` 这里使用了`json.dump`方法,直接将数据写入到文件中[^3]。 #### 注意事项 - 在序列化过程中,非基本数据类型(如自定义类实例)需要额外处理。可以通过`default`参数指定转换逻辑。 - 如果对象包含无法序列化的属性(如函数或复杂对象),需要提供自定义的序列化方法[^4]。 例如,对于自定义类对象的序列化: ```python class Person: def __init__(self, name, age): self.name = name self.age = age person = Person("Bob", 30) # 自定义序列化方法 def custom_serializer(obj): if isinstance(obj, Person): return {"name": obj.name, "age": obj.age} raise TypeError(f"Type {type(obj)} not serializable") # 序列化自定义对象 json_string = json.dumps(person, default=custom_serializer, indent=4) print(json_string) ``` 上述代码通过`default`参数指定了自定义序列化逻辑,确保复杂对象能够被正确转换为JSON格式[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值