os模块与sys模块
目录os模块
os模块可以帮助我们直接对操作系统进行操作。我们可以直接调用操作系统的可执行文件、命令,直接操作文件、目录等等。在系统运维的核心基础。
os.system调用操作系统命令
import os
cmd = 'ping www.baidu.com'
os.system(cmd)
os模块的常用命令
import os
1、创建目录(文件夹)
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\d2222')
# 只能删除空的多级目录
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()) # D:\pythonProject\111 获取当前目录
os.chdir('..') # D:\pythonProject 切换到上一级目录
6、动态获取项目根路径
print(os.path.abspath(__file__))
# D:\pythonProject\111\代码练习.py
# 获取执行文件的绝对路径
print(os.path.dirname(__file__))
# D:/pythonProject/111
# 获取执行文件所在的目录路径
7.判断路径是否存在(文件、目录)
print(os.path.exists(r'xzcxzc.py'))
# 判断文件路径是否存在 True
print(os.path.exists(r'D:\pythonProject\111'))
# 判断目录是否存在 True
print(os.path.isfile(r'xzcxzc.py'))
# 判断路径是否是文件 True
print(os.path.isfile(r'D:\pythonProject\111'))
# 判断路径是否是文件 False
print(os.path.isdir(r'01 os模块.py'))
# False isdir判断是否为目录
print(os.path.isdir(r'D:\pythonProject\111'))
# True isdir判断是否为目录
8.路径拼接
s1 = r'D:\pythonProject03\day19'
s2 = r'01 os模块.py'
print(f'{s1}\{s2}')/print(os.path.join(s1, s2))# 两种办法都可以
# D:\pythonProject03\day19\01 os模块.py
# 涉及到路径拼接一定不要自己做,因为不同的操作系统路径分隔符不一样。
9.获取文件大小(字节)
print(os.path.getsize(r'a.txt'))
# 12(a.txt里面写的 hello,你好) 此操作中当前的操作环境与文档需在同个目录下
sys模块
sys模块主要负责与python解释器进行交互,该模块提供了一系列用于控制python运行环境的函数和变量。
os模块与sys模块从名称上看好像有些类似,实际它们没什么关系,os模块主要负责与操作系统进行交互。
sys模块的使用
import sys
dir(sys)
['sys内定义的所有名称被组织成列表输入']
import sys
print(sys.path)
# 获取执行文件的sys.path
#['D:\\pythonProject\\111', 'D:\\pythonProject\\111', 'D:\\PyCharm 2021\\plugins\\python\\helpers\\pycharm_display', 'D:\\Python38\\python38.zip', 'D:\\Python38\\DLLs', 'D:\\Python38\\lib', 'D:\\Python38', 'D:\\Python38\\lib\\site-packages', 'D:\\PyCharm 2021\\plugins\\python\\helpers\\pycharm_matplotlib_backend']
print(sys.getrecursionlimit())
# 1000 获取python解释器默认最大递归深度
import sys
sys.setrecursionlimit(2000)
print(sys.getrecursionlimit())
# 2000 修改python解释器默认最大递归深度
print(sys.version) # sys模块的版本 3.8.3 (tags/v3.8.3:6f8c832, May 13 2020, 22:37:02) [MSC v.1924 64 bit (AMD64)]
print(sys.platform)
# 平台信息 win32(了解即可)
winver
返回 Python 解释器主版号。
copyright
返回 Python 版权信息。
modules
以字典类型返回系统导入的模块。
byteorder
返回本地字节规则的指示器。
executable
返回 Python 解释器所在路径。
json模块
json模块是python内置的库,使用的时候直接导入就行。json模块的主要功能是将序列化数据从文件中读取出来或者存入文件。
json模块只有四个方法
dump() , load() , dumps() , loads()
'''
dump()是将数据存入文件中,load()是用于读取文件。
dumps()和loads()是对python对象进行操作。dumps()是将python对象编码成json字符串,loads()是将json字符串解码成python对象。
'''
json.dumps()和json.dump()的区别
json.dumps()
把python对象转换成json对象的一个过程,生成的是字符串。
json.dump()
把python对象转换成json对象生成一个fp的文件流,和文件相关。
json.loads()和json.load()的区别同上类似,加上s的方法是用来处理字符串类型的,而不加s是用来处理文件类型的。
json.dumps()
对数据进行编码,形成json格式的数据。
import json
if __name__ == '__main__':
data_dict = {"key2": "value2", "key1": "value", "key3": "value3"}
# 默认转换的json数据是无序的。如果将参数sort_keys改为True,
# 则会根据key值将数据进行排序。
json1 = json.dumps(data_dict, sort_keys=True)
# 默认无序
json2 = json.dumps(data_dict)
print(json1)
print(json2)
# 输出{"key1": "value", "key2": "value2", "key3": "value3"}
# 输出{"key2": "value2", "key1": "value", "key3": "value3"}
json.loads()
和dumps相反,loads函数则是将json格式的数据解码,转换为Python字典。
import json
if __name__ == '__main__':
data_str = '{"key1": "value1", "key2": "value2", "key3": "value3"}'
data_dict = json.loads(data_str)
print(data_dict)
#输出:{'key1': 'value1', 'key2': 'value2', 'key3': 'value3'}
json.dump()和json.load()
与dumps()和loads的功能相似,只不过dump()和load是处理文件的。
import json
if __name__ == '__main__':
data = '{"key1": "value1", "key2": "value2", "key3": "value3"}'
with open(' data.json', '', encoding='utf-8') as f:
json.dump(data, f)
# 等同于f.write(json.dumps (data))
with open(' data.json', 'r') as f:
infos = json.load(f)
# infos = json.loads (f.read())#和上面的效果一样
json模块运用示例
用户登录注册功能
import os
import json
# 注册功能
# 1.获取执行文件所在的目录路径
base_dir = os.path.dirname(__file__) # D:/pythonProject03/day19
# 2.拼接出db目录的路径
db_dir = os.path.join(base_dir, 'db') # D:/pythonProject03/day19/db
# 3.创建db目录
if not os.path.isdir(db_dir):
os.mkdir(db_dir)
# 4.获取用户数据
# username = input('username>>>:').strip()
# password = input('password>>>:').strip()
# 4.1.判断用户名是否已存在
# print(os.listdir(db_dir)) # ['jason.json', 'kevin.json', 'tony.json'] 方式1
# user_file_path = os.path.join(db_dir, f'{username}.json') 方式2
# 5.构造用户字典
# user_dict = {
# 'username': username,
# 'password': password,
# 'account': 15000, # 账户余额
# 'shop_car': [] # 购物车
# }
# 6.拼接存储用户数据的文件路径
# user_file_path = os.path.join(db_dir, f'{username}.json') # D:/pythonProject03/day19/db/jason.json
# 7.写入文件数据
# with open(user_file_path,'w',encoding='utf8') as f:
# json.dump(user_dict, f)
username = input('username>>>:').strip()
# 1.拼接上述用户名组成的文件路径
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()
# 2.获取用户真实数据字典
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('密码错误')
标签:sys,json,模块,print,path,os
From: https://www.cnblogs.com/zhiliaowang/p/16811402.html