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 """

相关