今日内容
os模块
os模块主要是与代码运行所在的操作系统打交道启动os:import os
-
1.创建单级或者多级目录(文件夹)
# 1.mkdir:只能创建单级目录
# 2.makedirs:可以创建多级 也可以单级
import os # 启动os模块
os.mkdir(r'di') # 相对路径 在执行文件的路径下创建目录 可以创建单级目录 不可以多级
os.makedirs(r'd2/d22/d222') # 可以创建多级 也可以单级
-
2.删除目录(文件夹)
# 1.rmdir:可以删除单级目录 不可以一次性删除多级目录 而且单级目录必须要是空目录
# 2.removedirs:可以删除多级目录 但是只能删除空的多级目录
import os # 启动os模块
os.rmdir(r'd1') # 删除单级目录 不可以多级 空目录
os.removedirs(r'd1/d22/d33') # 可以删除空多级目录 但是目录里面不可以有东西
-
3.指定路径下的内容名称
import os
print(os.listdir(r'输入路径位置'))
-
4.删除文件/重命名文件
# 1.rename:可以更改文件名
# 2.remove:可以删除文件
import os # 启动os模块
os.rename(r'a.txt', r'aaa.txt') # 更改a.txt改成aaa.txt
os.remove(r'aaa.txt') # 删除aaa.txt
-
5.获取当前目录/切换当前目录
# 1.geicwd:显示当前目录
# 2.chrdir:返回上一级目录
import os # 启动os模块
print(os.getcwd()) # 显示当前目录 D:\pycharm\pythonProject2\第19
os.chdir('..') # 返回上一级目录
print(os.getcwd()) # D:\pycharm\pythonProject2
os.mkdir(r'ing') # 联合mkdir使用在pythonProject2下创建ing文件夹
-
6.动态获取项目跟路径****
# 1.path.abspath(__file__):获取执行文件的绝对路径
# 2.path.dirname(__file__):获取执行文件所在的目录路径
print(os.path.abspath(__file__)) # 获取执行文件的绝对路径 D:\pycharm\pythonProject2\第19\第19、2.py
print(os.path.dirname(__file__)) # 获取执行文件所在的目录路径 D:/pycharm/pythonProject2/第19
-
7.判断路径是否存在(文件/目录) / 判断路径是否是(文件/目录)
# 1.os.path.exists(r''):判断文件路径或者目录路径是否存在
# 2.os.path.isfile(r''):判断路径是否是文件
# 3.os.path.isdir(r''):判断路径是否是目录
print(os.path.exists(r'aaa.txt ')) # 判断文件路径是否存在 True
print(os.path.exists(r'D:\pycharm\pythonProject2\第19')) # 判断目录是否存在 True
print(os.path.isfile(r'aaa.txt')) # 判断路径是否是文件 True
print(os.path.isfile(r'D:\pycharm\pythonProject2\第19')) # 判断路径是否是文件 False
print(os.path.isdir(r'a.txt')) # 判断是否是目录 False
print(os.path.isdir(r'D:\pycharm\pythonProject2\第19')) # 判断是否是目录True
-
8.路径拼接****
# 1.os.path.join():将多个路径进行拼接。或者称之为合并目录
a1 = r'D:\pycharm\pythonProject2\第19'
b1 = r'a.txt'
print(os.path.join(a1, b1)) # 拼接结果D:\pycharm\pythonProject2\第19\a.txt
- 9.获取文件大小(查看文件字节)
# 1.os.path.getsize():查看文件有多少字节 英文1字节 中文3字节
print(os.path.getsize(r'a.txt')) # 查看a.txt有多少字节
sys模块
import sys 主要与python解释器打交道
print(sys.path) # 执行文件的sys.path
print(sys.getrecursionlimit()) # 获取python解释器的默认最大递归深度1000
sys.setrecursionlimit(11500) # 更改递归深度
print(sys.getrecursionlimit()) # 打印最大递归深度11500
print(sys.version) # 获取解释器版本3.8.6 (tags/v3.8.6:db45529, Sep 23 2020, 15:52:53) [MSC v.1927 64 bit (AMD64)]
print(sys.platform) # 平台信息win32(了解即可)
json模块
json模块也成为序列化模块 序列化可以打破语言限制实现不同编程语言之间数据交互
json格式数据的形式:字符串类型而且都是双引号
使用json函数需要导入json库:import json
针对数据
# json.dumps:将Python对象编码成 json 字符串 简单说把数据转成字符串
dumps(): # 把数据转成字符串
# json.loads:将已编码的json字符串解码为 Python 对象
loads(): # 把字符串符号''去掉
针对文件读写
# json.dump:简称序列化把对象转换为字节序列的过程称为对象的序列化
dump(x, f): # 将x的内容写入f且不改变格式
# jaom.load:反序列化把字节序列恢复为对象的过程称为对象的反序列化
load(x, f): # 读取f保存为x 同样不改变格式
json实战
用户登入注册功能
#先调用模块
import os
import json
# 1.先获取执行文件所在的目录
base_dir = os.path.dirname(__file__)
print(os.path.dirname(__file__))
# D:/pycharm/pythonProject2/第19
# 2.拼接出目录db路径
db_dir = os.path.join(base_dir, 'db')
print(os.path.join(base_dir, 'db'))
# D:/pycharm/pythonProject2/第19\db
# 3.创建目录db
if not os.path.isdir(db_dir):
os.mkdir(db_dir)
# 4.获取用户数据
username = input('username:').strip()
password = input('password:').strip()
# 5.判断用户名是否存在
user_file_path = os.path.join(db_dir, f'{username}.json')
if not os.path.exists(user_file_path):
#'''f后面是名字.json的文件名,这个文件名加入db_dir文件路径下'''
# 6.构造用户字典
user_dict = {
'username': username,
'password': password,
'account': 15000,
'shop_car':[]
}
#6.拼接存储用户数据的文件路径
user_file_path = os.path.join(db_dir, f'{username}.json')
#7.写入文件数据
with open(user_file_path,'w',encoding='utf8') as f:
json.dumps(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()
# 8.获取用户真实数据字典
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('密码错误')
标签:json,模块,print,path,txt,os,目录
From: https://www.cnblogs.com/lsl1/p/16811508.html