python知识点二十(random模块 os模块 sys模块 序列化模块 subprocess模块 )
昨日内容回顾
-
转义
在正则表达式中转义推荐使用\(单杠只能取消单个转义符) 在python中转义推荐使用元字符r -
re模块
import re re.findall(正则表达式,待匹配的文本) # 去待匹配文本匹配所有符合条件的数据 结果是一个列表 re.search(正则表达式,待匹配的文本) # 去待匹配文本匹配一个符合条件的数据就结束 结果是一个对象 .group(index\reg_name) re.match(正则表达式,待匹配的文本) # 去待匹配文本开头匹配一个符合条件的数据就结束 结果是一个对象 .group(index\reg_name) obj = re.compile(正则表达式) # 提前定义好正则后续可以反复使用 obj.findall(待匹配的文本) obj.search(待匹配的文本) obj.match(待匹配的文本) re.finditer(正则表达式,待匹配的文本) # 结果是一个迭代器 # 无名分组与有名分组 无名分组其实就是对某一块正则表达式加括号 (\d+) 有名分组就是在加括号前提之上再给组命名 (?P<name>\d+) # 分组优先 findall()默认是分组优先展示 取消分组优先 (?:\d+) (?:?P<name>\d+) -
正则实战案例
红牛分公司初体验(最好自己多写几遍感受感受) -
collections模块
具名元组 队列 双端队列 有序字典 默认值字典 计数器 -
time模块
""" 时间戳 结构化时间 格式化时间 """ import time time.time() time.sleep() time.strftime() # %Y %m %d %H %M %S %X -
datetime模块
import datetime datetime.datetime.today() datetime.date.today() datetime.timedelta(days,month...)
今日内容概要
-
random模块
随机数模块 -
os模块
跟操作系统打交道的模块 -
sys模块
跟python解释器打交道的模块 -
序列化模块
使用频率最高的(前后端数据交互) json模块 -
subprocess模块
类似于远程操作工具
今日内容详细
random随机数模块
import random
# print(random.random()) # 随机产生一个0-1之间的小数
# print(random.randint(1, 6)) # 随机产生一个1-6之间的整数 掷骰子
# print(random.uniform(1,6)) # 随机产生一个1-6之间的小数
# print(random.choice(['特等奖', '一等奖', '二等奖', '谢谢惠顾', '惊喜大奖之如花抱回家'])) # 随机抽取一个
# print(random.sample(['安徽省', '江苏省', '山东省', '海南省', '广东省', '台湾省'], 3)) # 随机抽取指定样本量
# l = [2, 3, 4, 5, 6, 7, 8, 9, 10, 'J', 'Q', 'K', 'A']
# random.shuffle(l) # 随机打乱容器类型中的诸多元素
# print(l)
# 搜狗公司笔试题
# 随机验证码可以是由 数字 小写字母 大小写字母 任意组合
# 编写能够产生五位数的随机验证码
'''ps:五位 每位都可以是三种情况之一'''
import random
def v_code(n):
code = ''
for i in range(n):
num=random.randint(0,9)
alf=chr(random.randint(65,90))
add=random.choice([num,alf])
code="".join([code,str(add)])
return code
n = int(input('输入你要生成验证码的位数:'))
print(v_code(n))
os模块
# 与操作系统打交道
import os
# 1.创建单级目录(文件夹)
os.mkdir('XXX老师精品课程集')
os.mkdir(r'xxx视频合集\r老师视频作品') 报错
# 2.创建多级目录(文件夹)
os.makedirs(r'xxx视频合集\r老师视频作品\2021选集')
# 3.删除空目录(文件夹)
# os.rmdir(r'xxx视频合集')
# os.removedirs(r'xxx视频合集')
# 4.获取当前文件所在的路径(可以嵌套 则为上一层路径)
BASE_DIR = os.path.dirname(__file__)
# 5.路径拼接(******) 能够自动识别不同操作系统分隔符问题
movie_dir = os.path.join(BASE_DIR, '老师教学视频')
# 6.列举出指定路径下的文件名称(任意类型文件)
data_movie_list = os.listdir('D:\py20\day21\老师教学视频')
while True:
for i, j in enumerate(data_movie_list):
print(i + 1, j)
choice = input('请选择你想要看的文件编号>>>:').strip()
if choice.isdigit():
choice = int(choice)
if choice in range(len(data_movie_list) + 1):
# 获取编号对应的文件名称
file_name = data_movie_list[choice - 1]
# 拼接文件的完整路径(******)
file_path = os.path.join(movie_dir, file_name) # 专门用于路径拼接 并且能够自动识别当前操作系统的路径分隔符
# # 利用文件操作读写文件
# with open(file_path, 'r', encoding='utf8') as f:
# print(f.read())
# 7.删除一个文件
# os.remove('a.txt')
# 8.修改文件名称
# os.rename('老文件名','新文件名')
# 9.获取当前工作路径
# print(os.getcwd())
# 10.切换路径
# os.chdir('D:/')
# with open(r'a.txt','wb') as f:
# pass
# 11.判断当前路径是否存在
print(os.path.exists('a.txt')) # False
print(os.path.exists('老师教学视频')) # True
print(os.path.exists('01 random模块.py')) # True
# 12.判断当前路径是否是文件
# print(os.path.isfile('01 random模块.py')) # True
# print(os.path.isfile('老师教学视频')) # False
# 13.判断当前路径是否是文件夹
# print(os.path.isdir('01 random模块.py')) # False
# print(os.path.isdir('老师教学视频')) # True
# 14.获取文件大小(字节数)
# print(os.path.getsize(r'a.txt'))
sys模块
# 主要与python解释器打交道
import sys
# print(sys.path)
# print(sys.version)
# print(sys.platform)
# print(sys.argv) # 获取当前执行文件的绝对路径
try:
username = sys.argv[1]
password = sys.argv[2]
if username == 'jason' and password == '123':
print('正常执行文件内容')
else:
print('用户名或密码错误')
except Exception:
print('请输入用户名和密码')
print('目前只能让你体验一下(游客模式)')
json序列化模块
json格式数据:跨语言传输
import json
d = {'username': 'jason', 'pwd': 123}
# 1.将python其他数据转换成json格式字符串(序列化)
# import json
# res = json.dumps(d)
# print(res,type(res)) # {"username": "jason", "pwd": 123}
# 2.将json格式字符串转成当前语言对应的某个数据类型(反序列化)
# res1 = json.loads(res)
# print(res1,type(res1)) # {'username': 'jason', 'pwd': 123} <class 'dict'>
# bytes_data = b'{"username": "jason", "pwd": 123}'
# bytes_str = bytes_data.decode('utf8')
# bytes_dict = json.loads(bytes_str)
# print(bytes_dict,type(bytes_dict))
"""
暂且可以简单的理解为
序列化就是将其他数据类型转换成字符串过程
json.dumps()
反序列化就是将字符串转换成其他数据类型
json.loads()
"""
# 将字典d写入文件
# with open(r'a.txt','w',encoding='utf8') as f:
# f.write(str(d))
# 将字典d取出来
# with open(r'a.txt','r',encoding='utf8') as f:
# data = f.read()
# print(dict(data))
# 将字典d写入文件
# with open(r'a.txt','w',encoding='utf8') as f:
# res = json.dumps(d) # 序列化成json格式字符串
# f.write(res)
# 将字典d取出来
# with open(r'a.txt','r',encoding='utf8') as f:
# data = f.read()
# res1 = json.loads(data)
# print(res1,type(res1))
# d1 = {'username': 'tony', 'pwd': 123,'hobby':[11,22,33]}
# with open(r'a.txt', 'w', encoding='utf8') as f:
# json.dump(d1, f)
# with open(r'a.txt','r',encoding='utf8') as f:
# res = json.load(f)
# print(res,type(res))
d1 = {'username': 'tony好帅哦 我好喜欢', 'pwd': 123,'hobby':[11,22,33]}
print(json.dumps(d1,ensure_ascii=False))
"""
# 并不是所有的数据类型都支持序列化
json.JSONEncoder 查看支持的数据类型
"""
subprocess模块
import subprocess
"""
1.可以基于网络连接上一台计算机(socket模块)
2.让连接上的计算机执行我们需要执行的命令
3.将命令的结果返回
"""
res = subprocess.Popen('tasklist',
shell=True,
stdout=subprocess.PIPE,
stderr=subprocess.PIPE
)
print('stdout',res.stdout.read().decode('gbk')) # 获取正确命令执行之后的结果
print('stderr',res.stderr.read().decode('gbk')) # 获取错误命令执行之后的结果
"""
windows电脑内部编码默认为GBK
"""
作业指导
import json
import os
BASE_DIR = os.path.dirname(__file__) # 当前文件路径
db_path = os.path.join(BASE_DIR,'db') # 在当前文件路径利用路径连接创建一个新文件夹 (只赋值未执行)
username = input('username>>>:')
password = input('password>>>:')
file_name = os.path.join(db_path,'%s.json'%username) # 在db文件夹中利用join创建文件 (只赋值,未执行)
with open(file_name,'w',encoding='utf8') as f:
data_dict = {'name':username,'pwd':password}
json.dump(data_dict,f)
"""
json格式数据存储到文本文件中 可以给文件后缀名命名为.json
"""
作业
1.组长/班长将每个小组/班级成员全部录入列表中 以后每次例会随机抽取主持人
2.尝试着将员工管理系统数据存储方式改为json格式(一个用户一个文件)
3.整理今日内容及博客

浙公网安备 33010602011771号