• 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([1, 2, 3]))
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)

image

搜狗公司笔试题

# 随机验证码可以是由 数字 小写字母 大小写字母 任意组合
# 编写能够产生五位数的随机验证码
code = ''
for i in range(5):
    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
print(code)

# 不限位数 => 函数传参
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)
code2 = get_code(10)
code3 = get_code(8)
print(code1,code2,code3)

二、os模块

与操作系统打交道

import os

1.创建单级目录(文件夹)	mkdir()
os.mkdir('XXX老师精品课程集')
os.mkdir(r'xxx视频合集\r老师视频作品')  # 报错

2.创建多级目录(文件夹)	makedirs()
os.makedirs(r'xxx视频合集\r老师视频作品\2021选集')

3.删除空目录(文件夹)	rmdir()
os.rmdir(r'xxx视频合集')
os.removedirs(r'xxx视频合集\r老师视频作品\2021选集')

4.获取当前文件所在的路径(可以嵌套,则为上一层路径)
BASE_DIR = os.path.dirname(__file__)
# print(BASE_DIR)  # D:/Work/pythonProject10

5.路径拼接	os.path.join()
movie_dir = os.path.join(BASE_DIR, '老师')
# print(movie_dir) # D:/Work/pythonProject10\老师

6.列举出指定路径下的文件名称(任意类型文件)	listdir()
res = os.listdir('D:\Work\pythonProject10')
print(res)  # ['.idea', '1.py']

7.删除一个文件	remove()
os.remove('a.txt')
8.修改文件名称	rename()
os.rename('老文件名','新文件名')
9.获取当前工作路径	getcwd()
print(os.getcwd())
10.切换路径	chdir()
os.chdir('D:/')
# with open(r'a.txt','wb') as f:
#     pass

11.判断当前路径是否存在	os.path.exists()
12.判断当前路径是否是文件	os.path.isfile()
13.判断当前路径是否是文件夹	os.path.isdir()
14.获取文件大小(字节数)	os.path.getsize()
import os

# 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())

三、sys模块

主要与python解释器打交道

import sys

sys.path	# 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值
sys.version	# 获取Python解释程序的版本信息
sys.platform	# 返回操作系统平台名称
sys.argv	# 获取当前执行文件的绝对路径
sys.exit(n)	# 退出程序,正常退出时exit(0),错误退出sys.exit(1)

# 绝对路径不存在时:
try:
    username = sys.argv[1]
    password = sys.argv[2]
    if username == 'jason' and password == '123':
        print('正常执行文件内容')
    else:
        print('用户名或密码错误')
except Exception:
    print('请输入用户名和密码')
    print('目前只能让你体验一下(游客模式)')

四、序列化模块json

json格式数据:跨语言传输

image

import json

d = {'username': 'jason', 'pwd': 123}
1.dumps()	序列化:将python其他数据转换成json格式字符串
res = json.dumps(d)
print(res, type(res))	# {"username": "jason", "pwd": 123} <class 'str'>
2.loads()	反序列化:将json格式字符串转成当前语言对应的某个数据类型
res1 = json.loads(res)
print(res1, type(res1))	# {'username': 'jason', 'pwd': 123} <class 'dict'>
"""
暂且可以简单的理解为
    序列化就是将其他数据类型转换成字符串过程
        json.dumps()
    反序列化就是将字符串转换成其他数据类型
        json.loads()
"""
# dumps()与loads()
# 将字典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))


# dump()与load()
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))
# {'username': 'tony', 'pwd': 123, 'hobby': [11, 22, 33]} <class 'dict'>

"""
并不是所有的数据类型都支持序列化
json.JSONEncoder  查看支持的数据类型
"""
# 文本内容含有汉字 需要指定解释器不操作ASCLL码转换 才可以正常显示汉字
d1 = {'username': 'tony好帅哦 我好喜欢', 'pwd': 123,'hobby':[11,22,33]}
print(json.dumps(d1,ensure_ascii=False))  # {"username": "tony好帅哦 我好喜欢", "pwd": 123, "hobby": [11, 22, 33]}

五、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
"""
posted on 2021-11-26 18:37  幽星  阅读(53)  评论(0)    收藏  举报