pythonos pathjson_python 模块二(os,json,pickle)

#################################总结#####################

os常用

os.makedirs('baby/安哥拉/特斯拉/黄晓明')

os.mkdir("baby/安哥拉/特斯拉/lvb") #上层文件夹必须存在

os.rmdir("baby/baobao/baby/黄晓明") #指定文件夹删除

print(os.path.dirname(r"D:\python_workspace_s18\day23 内置模块02\userinfo"))#获取当前的文件名 D:\python_workspace_s18\day23 内置模块02

print(os.path.basename(r"D:\python_workspace_s18\day23 内置模块02\userinfo"))#userinfo

print(os.path.exists(r"D:\python_workspace_s18\day23 内置模块02") )#查看当前目录是否存在 不存在为False

======重命名文件夹=====

os.rename(r'temp1\inner\inner2','temp1\inner\haiyan')

=====删除文件夹和删除文件=========

# 先删文件,

os.remove(r'temp1\inner\file')

# 再删文件夹

os.removedirs(r'temp1\inner\haiyan') #删除一个文件夹的时候,如果上一级的文件夹是空的,就一并删除了。以此类推

os.rmdir((r'temp1\inner') )#只删除一个文件夹

pickle(重点)

可以将我们python中的任意数据类型转化成bytes并写入到文件中,同样也可以把文件中写好的bytes转换回我们python的数据,这个过程被称为反序列化

1. dumps() 把对象序列化成字节

2. loads() 把字节反序列化成对象

3. dump() 把对象序列化写入文件

4. load() 把文件中的内容反序列化成对象

json(重点中的重点)

json将python中常见的字典, 列表转化成字符串,是目前后端数据交互使用频率最高的一种数据格式

python: True, False, None

json: true, false, null

1. dumps() 把对象序列化成json

2. loads() 把json反序列化成对象

3. dump() 把对象序列化写入文件

4. load() 把文件中的内容反序列化成对象

使用json模块完成:

1. 字典-> 字符串

import json

dic={'a'='hehe','b'='haha'}

s=json.dumps(dic,ensure_ascii=False)#json处理中文问题

print(s)#把对象序列化成json

2. 字符串 -> 字典

d=json.loads(

'{"baby": null, "hxm": false, "syy": "史杨杨"}'

)

print(d)#把json反序列化成对象

importsys#print(sys.platform)

print(sys.path) #找模块的. 必须要记住. 模块的搜索路径

importpickle#classElephant:def __init__(self, name, weight, height):

self.name=name

self.weight=weight

self.height=heightdeftiaoxi(self):print(f"{self.name}大象特别喜欢调戏人")

e= Elephant("宝宝", "185T", "175")

e.tiaoxi()#序列化

bs = pickle.dumps(e) #把对象进行序列化

print(bs)

bs= b'\x80\x03c__main__\nElephant\nq\x00)\x81q\x01}q\x02(X\x04\x00\x00\x00nameq\x03X\x06\x00\x00\x00\xe5\xae\x9d\xe5\xae\x9dq\x04X\x06\x00\x00\x00weightq\x05X\x04\x00\x00\x00185Tq\x06X\x06\x00\x00\x00heightq\x07X\x03\x00\x00\x00175q\x08ub.'

#发序列化

dx = pickle.loads(bs) #发序列化. 得到的是大象

dx.tiaoxi()###########################实例二####################

e1 = Elephant("宝宝", "185T", "175")

e2= Elephant("宝贝", "120T", "120")

lst=[e1, e2]

pickle.dump(lst, open("大象", mode="wb"))

lst= pickle.load(open("大象", mode="rb"))for dx inlst:

dx.tiaoxi()

######################json################

importjson

dic= {"baby":None, "hxm":False, "syy":"史杨杨"}

s= json.dumps(dic, ensure_ascii=False) #json处理中文的问题

print(s+'json')#把对象序列化成json

d= json.loads('{"baby": null, "hxm": false, "syy": "史杨杨"}')print(d['baby'])#把json反序列化成对象

f= open("baby.json", mode="w", encoding="utf-8")#把对象序列化成json写入文件

json.dump({"baby":None, "hxm":False, "syy":"史杨杨"}, f, ensure_ascii=False)##把json反序列化成对象 从文件读取

f = open("baby.json", mode="r", encoding="utf-8")

obj=json.load(f)print(obj)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
安装_pickle模块不需要单独操作,因为_picklePython的内置模块。_pickle模块用于序列化对象,即将对象转换成字节流以便存储或传输。在Python中使用_pickle模块可以方便地将对象持久化保存到磁盘上,并在需要时将其读取出来恢复成原来的对象。 在使用Python 3时,默认已经自带_pickle模块,无需进行额外的下载和安装。可以直接在代码中通过`import pickle`来导入_pickle模块,然后使用_pickle模块的相关函数进行对象的序列化和反序列化操作。 常用的_pickle模块函数包括: - dumps(obj):将对象序列化为字节流 - loads(data):将字节流反序列化为对象 - dump(obj, file):将对象序列化并保存到文件中 - load(file):从文件中读取字节流并将其反序列化为对象 在导入_pickle模块后,就可以使用上述函数进行对象的序列化和反序列化操作了。例如,可以使用dumps函数将对象转换成字节流并打印出来,然后使用loads函数将字节流转换回对象。 需要注意的是,使用_pickle模块进行对象的序列化和反序列化时,可能会存在一些安全风险,因为_pickle模块可以执行任意的Python代码。如果需要在不可信的环境下进行对象序列化和反序列化操作,建议使用更安全的序列化模块,如JSON模块。 总之,Python 3已经内置了_pickle模块,可以直接导入并使用相关函数进行对象的序列化和反序列化操作,无需额外的下载和安装。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值