os模块(重要)
os模块主要与代码运行所在的操作系统打交道
import os
1. 创建目录(文件夹)
ps:加上r是解决对文件路径并且撬棍跟一些字母的组合会产生特殊的含义导致路径查找混乱
os.mkdir(r'd1')
os.mkdir(r'd2\d22\d222')
os.makedirs(r'd2\d22\d222')
os.makedirs(r'd3')
2. 删除目录(文件夹)
os.rmdir(r'd1')
os.rmdir(r'd2\d22\d222')
os.removedirs(r'd2\d22')
os.removedirs(r'd2\d22\d222')
os.rmdir(r'd3')
3.列举指定路径下内容名称
print(os.listdir())
print(os.listdir(r'D:\\'))
4. 删除/重命名文件
os.rename(r'a.txt', r'aaa.txt')
os.remove(r'aaa.txt')
5.获取/切换当前工作目录
print(os.getcwd())
os.chdir('..')
print(os.getcwd())
os.mkdir('hei')
6.动态获取项目根路径(重要)
print(os.path.abspath(__file__))
print(os.path.dirname(__file__))
7. 判断路径是否存在(文件、目录)
print(os.path.exists(r'test2.py'))
print(os.path.exists(r'D:/pythonProject/day1'))
print(os.path.isfile(r'test2.py'))
print(os.path.isfile(r'D:/pythonProject/day1'))
print(os.path.isdir(r'D:/pythonProject/day1'))
print(os.path.isdir(r'test2.py'))
8. 路径拼接(重要)
s1 = r'D:/pythonProject/day1'
s2 = r'test2.py'
print(f'{s1}\{s2}')
"""
涉及到路径拼接一定不要自己做 因为不同的操作系统路径分隔符不一样
"""
print(os.path.join(s1,s2))
9.获取文件大写(字节)
print(os.path.getsize(r'a.txt'))
sys模块
import sys
print(sys.path)
print(sys.getrecursionlimit())
sys.setrecursionlimit(1500)
print(sys.version)
print(sys.platform)
res = sys.argv
if len(res) != 3:
print('执行命令缺少了用户名或密码')
else:
username = res[1]
password = res[2]
if username == 'jason' and password == '123':
print('jason 文件正常执行')
else:
print('你不是jason 无权执行该文件')

json模块
json模块也称为序列化模块 序列化可以打破语言限制实现不同编程语言之间数据交互
序列化: 将数据结构或对象转换成二进制串的过程
反序列化:将在序列化过程中所生成的二进制串转换成数据结构或者对象的过程
json格式数据的作用
实现不同编程语言数据可以互相交互
json格式数据的形式
字符串类型并且引号都是双引号
import json
json相关操作
针对数据
json.dumps() 序列化(将python数据类型转换成json格式字符串)
json.loads() 反序列化(将json格式字符串转换成对应的数据类型)
dict1 = {'name':'jason','pwd':123,'age':18}
str_dcit1 = json.dumps(dict1) # 序列化:将一个字典转换成一个字符串
print(type(str_dcit1),str_dcit1) # <class 'str'> {"name": "jason", "pwd": 123, "age": 18}
# ps:json转换完的字符串类型的字典中的字符串是由""表示的
dict2 = json.loads(str_dcit1) # 反序列化:将一个字符串格式的字典转换成一个字典
print(type(dict2), dict2) # <class 'dict'> {'name': 'jason', 'pwd': 123, 'age': 18}
# ps:要用json的loads功能处理的字符串类型的字典中的字符串必须由""表示
list_dic = [1,['aa','bb','cc'],3,{'ke1':'vu1','ke2':'vu2'}]
str_dict = json.dumps(list_dic) # 可以处理嵌套数据类型
print(type(str_dict), str_dict) # <class 'str'> [1, ["aa", "bb", "cc"], 3, {"ke1": "vu1", "ke2": "vu2"}]
list_dic2 = json.loads(str_dict)
print(type(list_dic2),list_dic2) # <class 'list'> [1, ['aa', 'bb', 'cc'], 3, {'ke1': 'vu1', 'ke2': 'vu2'}
针对文件
json.dump() 将其它数据类型直接写入文件(自动转json格式字符串)
json.load() 将文件数据直接转成对应的数据类型(自动反序列化)
data = {'name':'jason', 'pwd':123, 'age':18}
with open(r'jason.json','w',encoding='utf8') as f:
json.dump(data,f)
with open(r'jason.json','r',encoding='utf8') as f:
loaded_json = json.load(f)
print(type(loaded_json),loaded_json) # <class 'dict'> {'name': 'jason', 'pwd': 123, 'age': 18}
json模块实战
import os
import json
base_dir = os.path.dirname(__file__)
db_dir = os.path.join(base_dir,'db')
if not os.path.isdir(db_dir):
os.mkdir(db_dir)
username = input('username>>>>:').strip()
password = input('password>>>>:').strip()
user_file_path=os.path.join(db_dir,f'{username}.json')
if not os.path.isfile(user_file_path):
print('用户名不存在')
exit(3)
user_dict = {'username': username,
'password': password,
'account': 15000,
'shop_car': []
}
user_file_path = os.path.join(db_dir,f'{username}.json')
with open(user_file_path,'w',encoding='utf8') as f:
json.dump(user_dict,f)
username = input('username>>>>>:').strip()
target_user_file_path = os.path.join(db_dir,f'{username}.json')
if not os.path.isfile(target_user_file_path):
print('用户名不存在')
else:
password = input('password>>>>').strip()
with open(target_user_file_path,'r',encoding='utf8') as f:
real_user_dict = json.load(f)
if password == real_user_dict.get('password'):
print('登录成功')
else:
print('密码错误')
作业
import os
import sys
json_count = 0
paths=os.path.dirname(os.path.dirname(__file__))
sys.path.append(paths)
json_type=input('请输入文件后缀')
dir_path=input('请输入具体统计路径')
if not os.path.dirname(dir_path):
print('这个路径不存在')
exit(2)
file_total = os.listdir(dir_path)
for i in file_total:
name,fix = i.split('.')
if f'.{fix}' == json_type:
json_count += 1
print(json_count)
teach_list = ['J老师视频合集','R老师视频合集','C老师视频合集','B老师视频合集']
import os
import sys
if not os.path.exists('jason'):
os.mkdir('jason')
os.chdir('jason')
for i in teach_list:
with open(r'%s'%i,'w',encoding='utf8') as f:
f.write(f'{i}\n{i}\n{i}')
def video(name):
"""
name 是文件名的参数,
以只读方式打开文件,循环遍历文件内容并打印出来
"""
with open(r'%s'%name,'r',encoding='utf8') as f:
for line in f:
print(line)
while True:
print("""
1.J老师视频合集
2.R老师视频合集
3.C老师视频合集
4.B老师视频合集
5.q(退出)
""")
choice = input('请输入序号')
if choice == '1':
video('J老师视频合集')
elif choice == '2':
video('R老师视频合集')
elif choice == '3':
video('C老师视频合集')
elif choice == '4':
video('B老师视频合集')
elif choice == '5':
break
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗