内置模块之random,os,sys,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, 10, 'aaa', '靓仔'])) # 随机抽取列表中的一个元素,可以是字符串类型
# print(random.sample([1,2,3,4,5,6,7,8,'aaa','bbb','ccc'],3)) # 随机抽取列表中的元素,可以设定个数。和choise类似,choice不能设定个数
# l = [2, 3, 4, 5, 6, 7, 8, 9, 10, 'J', 'Q', 'K', 'A']
# random.shuffle(l) # 随机打乱容器类型中的诸多元素
# 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)
code2 = get_code(10)
code3 = get_code(8)
print(code1,code2,code3)
os模块

# 与操作系统打交道
import os
# os.mkdir('创建新文件夹,只能创建单级文件夹,这里设置名字(不能创建多级文件)')
# os.makedirs(r'创建新文件夹\r可以再套一个文件夹') # 开头先用r取消转义,中间\r前后可以更改名字
# os.rmdir('删除空文件夹这里填写名字')# 非空文件夹会报错
# os.removedirs(r'xxx视频合集') #就算文件夹内有东西也可以删
# 获取当前文件所在的路径(可以嵌套 则为上一层路径)
# BASE_DIR = os.path.dirname(__file__)
# 路径拼接(******) 能够自动识别不同操作系统分隔符问题
# movie_dir = os.path.join(BASE_DIR, '老师教学视频')
# base_dir = os.path.dirname(__file__) # 查看当前文件所在位置。
# list_dir = os.path.join(base_dir, '/bin') # 把目录和文件名合成一个路径
# data_movie_list = os.listdir(r'D:/PycharmProjects/bin') # 返回这个目录下的文件组织成列表
# for i, j in enumerate(data_movie_list): # 将循环文件列表,枚举赋值给i,j 并打印出来,由于枚举是0开始,所以枚举+1
# print(i + 1, j)
# choice = input('请选择您要看的文件编号>>>:').strip()
# if choice.isdigit():
# choice = int(choice) # 将用户输入的字符串数字转成整型
# if choice in range(len(data_movie_list) + 1): # 如果用户输入的数字在列表长度+1的range循环内(顾头不顾尾)
# file_name = data_movie_list[choice - 1] # 用户输入的数字-1的索引所对应的文件名赋值给file_name
# file_path = os.path.join(list_dir, file_name) # 文件的绝对路径等于文件所在位置加上文件名字
# print(file_path)
# with open(file_path, 'r', encoding='utf8')as f: # 打开文件的绝对路径赋值给f,选择只读utf8编码
# print(f.read())
# 删除一个文件
# os.remove('a.txt')
# 修改文件名称
# os.rename('老文件名','新文件名')
# 获取当前工作路径
# print(os.getcwd())
# 切换路径
# 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格式数据:跨语言传输
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
"""


浙公网安备 33010602011771号