1.os模块
os模块主要针对操作系统,一般用来操作文件系统
os.makedirs()可以一次性创建多级目录
os.rmdir()删除一个文件夹
os.path.dirname() 获取到文件的文件夹
import os 必须要记住.很常用 os.makedirs("baby/安哥拉/特斯拉/黄晓明") # 可以一次性创建多级目录 os.mkdir("hyf\zxx\lvb") # 上层文件夹必须存在 os.removedirs("baby/安哥拉/特斯拉/黄晓明") # 可以帮我们删除当前这个目录级中的所有空文件夹 需要记住 os.rmdir("baby/baobao/baby/黄晓明") # 指定文件夹删除 os.system("dir") print(os.popen("dir").read()) # 执行shell脚本或者cmd命令 print(os.getcwd()) # 当前程序运行的文件夹 D:\python_workspace_s18\day23 内置模块02 os.chdir("baby") # 改变工作目录 print(os.getcwd()) f = open("../userinfo", mode="r", encoding="utf-8") for line in f: print(line) os.path 和路径相关的内容 print(os.path.abspath('userinfo') ) # 把相对路径改成绝对路径 print(os.path.split(r"D:\python_workspace_s18\day23 内置模块02\userinfo")) print(os.path.dirname(r"D:\python_workspace_s18\day23 内置模块02\userinfo")) print(os.path.basename(r"D:\python_workspace_s18\day23 内置模块02\userinfo")) print(os.path.exists(r"D:\python_workspace_s18\day23 内置模块02") ) # 存在? exit()
2. sys
主要针对的是python解释器
sys.path 模块的查找路径
import sys # print(sys.platform) print(sys.path) # 找模块的. 必须要记住. 模块的搜索路径 sys.path.append("D:\\python_workspace_s18\\day21 继承") import master master.chi()
3.序列化
序列化就是把一个对象拍散,把拍散的内容再整合成对象,就叫做反序列化
4. pickle
把一个对象进行序列化操作
1.dumps() 把对象序列化成字节
2.loads() 把字节反序列化成对象
3.dump()把对象序列化写入文件
4.load() 把文件中的内容反序列化成对象
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") f = open("大象", mode="wb") # 这也是序列化 pickle.dump(e1, f) # 没有s的这个方法是把对象打散写入到文件, 序列化的内容不是给人看的 pickle.dump(e2, f) # 没有s的这个方法是把对象打散写入到文件, 序列化的内容不是给人看的 f = open("大象", mode="rb") while 1: try: obj = pickle.load(f) obj.tiaoxi() except Exception: break 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 in lst: dx.tiaoxi()
5.json
有些类似与python中的字典,但是有一点不一样的地方是
在python中, 布尔值和空表示为 True,False,None
而在json中,表示为true, false, null
1.dumps() 把对象序列化成字节
2.loads() 把字节反序列化成对象
3.dump()把对象序列化写入文件
4.load() 把文件中的内容反序列化成对象
import json dic = {"baby":None, "hxm":False, "syy":"史杨杨"} s = json.dumps(dic, ensure_ascii=False) # json处理中文的问题 print(s) d = json.loads('{"baby": null, "hxm": false, "syy": "史杨杨"}') print(d['baby']) f = open("baby.json", mode="w", encoding="utf-8") json.dump({"baby":None, "hxm":False, "syy":"史杨杨"}, f, ensure_ascii=False) f = open("baby.json", mode="r", encoding="utf-8") obj = json.load(f) print(obj)