python day21
import random print(random.random()) # 随机产生一个0-1之间的小数 print(random.randint(1,6)) # 随机产生一个1-6之间的整数 相当于掷骰子 print(random.unifrom(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'] # 随机打乱容器类型中的诸多元素 print(l) 搜狗公司笔试题 随机验证码可以是由 数字 小写字母 大写字母 任意组合 缩写能够产生五位数的随机验证码 """ps:五位 每位都可以是三种情况之一""" def get_code(n): # 提前定义一个储存验证码的变量 code = '' # 由于需要产生五位 每一位的操作都是一样的 所以肯定需要使用循环 for i in range(n): # 随机产生一个数字 random_int = str(random.randint(0,9)) # 随机产生一个大写字母 random_upper = chr(random.randint(65,90)) # 随机产生一个小写字母 random_lower = chr(random.randint(97,122)) # 随机选取一个 temp = random.choice([random_int, random_upper, random_lower]) # 拼接到字符串中 code += temp return code code1 = get_code(5) code1 = get_code(10) code1 = get_code(8) print(code1,code2,code3)

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视频合集') BASE_DIR = os.path.dirname(__file__) 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'))

# 主要与python解释器打交道 import sys 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)) print(dict(data)) 将字典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': '今天星期五 可以放假了', '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('stdout',res.stder.read().decode('gbk')) # 获取错误命令执行之后的结果 """ windows电脑内部编码默认为GBK """


浙公网安备 33010602011771号