Python模块
一.Random随机数模块
1 import random 2 print(random.random()) # 随机产生一个0-1之间的小数 3 print(random.randint(1, 6)) # 随机产生一个1-6之间的整数 掷骰子 4 print(random.uniform(1,6)) # 随机产生一个1-6之间的小数 5 print(random.choice(['特等奖', '一等奖', '二等奖', '谢谢惠顾', '惊喜大奖之如花抱回家'])) # 随机抽取一个 6 print(random.sample(['安徽省', '江苏省', '山东省', '海南省', '广东省', '台湾省'], 3)) # 随机抽取指定样本量 7 l = [2, 3, 4, 5, 6, 7, 8, 9, 10, 'J', 'Q', 'K', 'A'] 8 random.shuffle(l) # 随机打乱容器类型中的诸多元素 9 print(l) # [10, 'Q', 'A', 2, 7, 8, 'J', 6, 5, 4, 9, 3, 'K']
实战案例
1 # 搜狗公司笔试题 2 # 随机验证码可以是由 数字 小写字母 大小写字母 任意组合 3 # 编写能够产生五位数的随机验证码 4 ''' 5 ps:五位 每位都可以是三种情况之一 6 ''' 7 8 import random 9 10 11 def index(n): 12 code = '' 13 for i in range(n): 14 number = str(random.randint(0, 9)) 15 english_lower = chr(random.randint(97, 122)) 16 english_upper = chr(random.randint(65, 90)) 17 add = random.choice([number, english_lower, english_upper]) 18 code = add + code 19 return code 20 21 22 res = index(4) 23 print(res)
二.os模块
这个模块是与操作系统打交道
1 # 与操作系统打交道 2 import os 3 4 # 1.创建单级目录(文件夹) 5 os.mkdir('坚持与努力') 6 os.mkdir(r'xxx视频合集\r老师视频作品') 7 # 2.创建多级目录(文件夹) 8 os.makedirs(r'xxx视频合集\r老师视频作品\2021选集') 9 # 3.删除空目录(文件夹) 10 os.rmdir(r'xxx视频合集') 11 os.removedirs(r'xxx视频合集') 12 # 4.获取当前文件所在的路径(可以嵌套 则为上一层路径) 13 BASE_DIR = os.path.dirname(__file__) 14 # 5.路径拼接(******) 能够自动识别不同操作系统分隔符问题 15 movie_dir = os.path.join(BASE_DIR, '老师教学视频') 16 # 6.列举出指定路径下的文件名称(任意类型文件) 17 data_movie_list = os.listdir('D:\py20\day21\老师教学视频') 18 while True: 19 for i, j in enumerate(data_movie_list): 20 print(i + 1, j) 21 choice = input('请选择你想要看的文件编号>>>:').strip() 22 if choice.isdigit(): 23 choice = int(choice) 24 if choice in range(len(data_movie_list) + 1): 25 # 获取编号对应的文件名称 26 file_name = data_movie_list[choice - 1] 27 # 拼接文件的完整路径(******) 28 file_path = os.path.join(movie_dir, file_name) # 专门用于路径拼接 并且能够自动识别当前操作系统的路径分隔符 29 # 利用文件操作读写文件 30 with open(file_path, 'r', encoding='utf8') as f: 31 print(f.read()) 32 # 7.删除一个文件 33 os.remove('a.txt') 34 # 8.修改文件名称 35 os.rename('老文件名', '新文件名') 36 # 9.获取当前工作路径 37 print(os.getcwd()) 38 # 10.切换路径 39 os.chdir('D:/') 40 with open(r'a.txt', 'wb') as f: 41 pass 42 # 11.判断当前路径是否存在 43 print(os.path.exists('a.txt')) # False 44 print(os.path.exists('老师教学视频')) # True 45 print(os.path.exists('01 random模块.py')) # True 46 # 12.判断当前路径是否是文件 47 print(os.path.isfile('01 random模块.py')) # True 48 print(os.path.isfile('老师教学视频')) # False 49 # 13.判断当前路径是否是文件夹 50 print(os.path.isdir('01 random模块.py')) # False 51 print(os.path.isdir('老师教学视频')) # True 52 # 14.获取文件大小(字节数) 53 print(os.path.getsize(r'a.txt'))
三.sys模式
1 import sys 2 3 print(sys.path) 4 print(sys.version) 5 print(sys.platform) 6 print(sys.argv) # 获取当前执行文件的绝对路径 7 try: 8 username = sys.argv[1] 9 password = sys.argv[2] 10 if username == 'jason' and password == '123': 11 print('正常执行文件内容') 12 else: 13 print('用户名或密码错误') 14 except Exception: 15 print('请输入用户名和密码') 16 print('目前只能让你体验一下(游客模式)')
四.序列化模块
1 import json 2 3 d = {'username': 'jason', 'pwd': 123} 4 # 1.将python其他数据转换成json格式字符串(序列化) 5 import json 6 res = json.dumps(d) 7 print(res,type(res)) # {"username": "jason", "pwd": 123} 8 # 2.将json格式字符串转成当前语言对应的某个数据类型(反序列化) 9 res1 = json.loads(res) 10 print(res1,type(res1)) # {'username': 'jason', 'pwd': 123}11 bytes_data = b'{"username": "jason", "pwd": 123}' 12 bytes_str = bytes_data.decode('utf8') 13 bytes_dict = json.loads(bytes_str) 14 print(bytes_dict,type(bytes_dict)) 15 """ 16 暂且可以简单的理解为 17 序列化就是将其他数据类型转换成字符串过程 18 json.dumps() 19 反序列化就是将字符串转换成其他数据类型 20 json.loads() 21 """ 22 # 将字典d写入文件 23 with open(r'a.txt','w',encoding='utf8') as f: 24 f.write(str(d)) 25 # 将字典d取出来 26 with open(r'a.txt','r',encoding='utf8') as f: 27 data = f.read() 28 print(dict(data)) 29 30 # 将字典d写入文件 31 with open(r'a.txt','w',encoding='utf8') as f: 32 res = json.dumps(d) # 序列化成json格式字符串 33 f.write(res) 34 # 将字典d取出来 35 with open(r'a.txt','r',encoding='utf8') as f: 36 data = f.read() 37 res1 = json.loads(data) 38 print(res1,type(res1)) 39 40 d1 = {'username': 'tony', 'pwd': 123,'hobby':[11,22,33]} 41 with open(r'a.txt', 'w', encoding='utf8') as f: 42 json.dump(d1, f) 43 with open(r'a.txt','r',encoding='utf8') as f: 44 res = json.load(f) 45 print(res,type(res)) 46 47 d1 = {'username': 'tony好帅哦 我好喜欢', 'pwd': 123, 'hobby': [11, 22, 33]} 48 print(json.dumps(d1, ensure_ascii=False)) 49 50 """ 51 # 并不是所有的数据类型都支持序列化 52 json.JSONEncoder 查看支持的数据类型 53 """
五.subprocess模块
1 import subprocess 2 3 """ 4 1.可以基于网络连接上一台计算机(socket模块) 5 2.让连接上的计算机执行我们需要执行的命令 6 3.将命令的结果返回 7 """ 8 res = subprocess.Popen('tasklist', 9 shell=True, 10 stdout=subprocess.PIPE, 11 stderr=subprocess.PIPE 12 ) 13 print('stdout',res.stdout.read().decode('gbk')) # 获取正确命令执行之后的结果 14 print('stderr',res.stderr.read().decode('gbk')) # 获取错误命令执行之后的结果 15 """ 16 windows电脑内部编码默认为GBK 17 """