常用内置模块

os与sys模块

这两个模块的作用类似但有不同,os模块主要是对运行文件所在的操作系统进行操作,而sys模块只对python解释器内文件进行操作

  • os模块

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:\pythonProject03\day19
os.chdir('..')  # 切换到上一级目录
print(os.getcwd())  # D:\pythonProject03
os.mkdir(r'hei')
# 6.动态获取项目根路径(重要)
print(os.path.abspath(__file__))  # 获取执行文件的绝对路径  D:/pythonProject03/day19/01 os模块.py
print(os.path.dirname(__file__))  # 获取执行文件所在的目录路径  D:/pythonProject03/day19
# 7.判断路径是否存在(文件、目录)
print(os.path.exists(r'01 os模块.py'))  # 判断文件路径是否存在  True
print(os.path.exists(r'D:\pythonProject03\day19'))  # 判断目录是否存在  True
print(os.path.isfile(r'01 os模块.py'))  # 判断路径是否是文件  True
print(os.path.isfile(r'D:\pythonProject03\day19'))  # 判断路径是否是文件  False
print(os.path.isdir(r'01 os模块.py'))  # False
print(os.path.isdir(r'D:\pythonProject03\day19'))  # True
# 8.路径拼接(重要)
s1 = r'D:\pythonProject03\day19'
s2 = r'01 os模块.py'

"""
涉及到路径拼接一定不要自己做,因为不同的操作系统路径分隔符不一样

"""
print(os.path.join(s1, s2))
# 9.获取文件大小(字节)
print(os.path.getsize(r'a.txt'))
  • sys模块

import sys

print(sys.path)  # 获取执行文件的sys.path
print(sys.getrecursionlimit())  # 获取python解释器默认最大递归深度
sys.setrecursionlimit(2000)  # 修改python解释器默认最大递归深度
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(了解即可)
res = sys.argv  #  主要用于在cmd中运行文件时添加条件,防止他人对文件进行操作
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格式数据的形式
字符串类型并且引号都是双引号

json相关操作

针对数据
json.dumps()  # 将单个字典数据转换为json模式模式数据
json.loads()  # 将单个json模式数据转换为python解释器字典数据类型
针对文件
json.dump()  # 将只含有字典类型数据的文本文件转换为json模式数据

json.load()  # 将只含有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('密码错误')

作业

编写一个统计指定文件类型的脚本工具
输入指定类型的文件后缀
eg:.txt
并给出一个具体路径 之后统计该类型文件在该文件下的个数
ps:简单实现即可 无需优化

import os  # 导入os模块
l1 = []  # 定义空列表
file_type = input('请输入您要查询的文件后缀名>>>:').strip()  # 获取用户输入
file_path = input('请输入您需要查找的文件路径>>>:').strip()
if os.path.isdir(file_path) == False:  # 判断文件路径是否存在
    global B
    print('文件路径输入错误!')
else:
    A = os.listdir(file_path)  # 获取文件夹内所有文件名称
    for i in A:  # 遍历文件名列表
        if file_type in str(i):  # 比对判断目标文件类型
            l1.append(str(i))  # 将目标文件名添加到空列表
            B = len(l1)  # 统计列表数据数量
print(f'路径{file_path}\中共有{file_type}文件{B}个')  # 格式化输出
posted @ 2022-10-20 21:29  逐风若梦  阅读(49)  评论(0编辑  收藏  举报