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('密码错误')
作业
标签:文件,常用,内置,file,json,模块,print,path,os From: https://www.cnblogs.com/lf17603472426/p/16811380.html编写一个统计指定文件类型的脚本工具
输入指定类型的文件后缀
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}个') # 格式化输出