昨日内容回顾
-
包的实际应用
内部含有__init__.py文件的文件夹 如果直接导入包名其实导入的是内部的__init__.py文件,所以包名点的方式其实是跟__init__.py文件要名字
-
编程思想的转变
1.面条版 2.函数版 3.模块版
-
软件开发目录规范
-项目名 --bin目录 ---start.py --conf目录 ---settings.py --core目录 ---src.py --interface目录 ---goods.py ---user.py ---accounts.py --lib目录 ---common.py --db目录 ---userinfo.txt --log目录 ---log.log --readme文件 ---项目说明书 --requirements.txt文件 ---项目必备模块及版本
-
collections模块
具名元组(namedtuple) 双端队列、队列、堆栈 有序字典、计数器
-
时间模块
""" 时间的三种格式 时间戳 格式化时间 结构化时间 """ time模块 import time time.time() time.strftime('%Y-%m-%d %H:%M:%S %X') time.localtime() time.sleep() datetime模块 import datetime datetime.datetime.today() 年月日时分秒 datetime.date.today() 年月日 datetime.timedelta(days=3) 时间差值
-
随机数模块
import random random.random() random.randint() random.randrange() random.choice() random.choices() random.sample() random.shuffle() chr() random.randint() random.choice()
今日内容概要
-
os与sys模块
os模块主要与操作系统打交道 sys模块主要与python解释器打交道
-
json模块
-
hashlib模块
今日内容详细
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(f'{s1}\{s2}')
"""
涉及到路径拼接一定不要自己做 因为不同的操作系统路径分隔符不一样
"""
# 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
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.loads()
针对文件
json.dump()
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('密码错误')
作业
1.编写一个统计指定文件类型的脚本工具
输入指定类型的文件后缀
eg:.txt
并给出一个具体路径 之后统计该类型文件在该文件下的个数
ps:简单实现即可 无需优化
2.针对json实操 尝试单文件多用户(一行一个)是否可实现>>>:哪个更方便
不要求完成 单纯体会两种思路的难易
3.编程小练习
有一个目录文件下面有一堆文本文件
eg:
db目录
J老师视频合集
R老师视频合集
C老师视频合集
B老师视频合集
文件内容自定义即可 要求循环打印出db目录下所有的文件名称让用户选择
用户选择哪个文件就自动打开该文件并展示内容
涉及到文件路径全部使用代码自动生成 不准直接拷贝当前计算机固定路径
4.周末大作业(尝试编写)
# 项目功能
1.用户注册
2.用户登录
3.添加购物车
4.结算购物车
# 项目说明
用户数据采用json格式存储到文件目录db下 一个用户一个单独的文件
数据格式 {"name":"jason","pwd":123}
# ps:文件名可以直接用用户名便于校验
用户注册时给每个用户添加两个默认的键值对(账户余额 购物车)
{"balance":15000,"shop_car":{}}
添加购物车功能 商品列表可以自定义或者采用下列格式
good_list = [
['挂壁面',3]
['印度飞饼', 22]
['极品木瓜', 666],
['土耳其土豆', 999],
['伊拉克拌面', 1000],
['董卓戏张飞公仔', 2000],
['仿真玩偶', 10000]
]
用户可以反复添加商品,在购物车中记录数量
{'极品木瓜':[个数,单价]}
结算购物车
获取用户购物车中所有的商品计算总价并结算即可
针对添加购物车和结算只有登录的用户才可以执行
标签:第十九,python,--,json,模块,print,path,os,目录
From: https://www.cnblogs.com/tengyifan888/p/16810459.html