python内置模块

python内置模块

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(['特等奖', '一等奖', '二等奖', '谢谢惠顾', '惊喜大奖带回家'])) # 随机抽取一个
print(random.sample(['安徽省', '江苏省', '山东省', '海南省', '台湾省'], 3)) # 随机抽取三个
l = [2, 3, 4, 5, 6, 7, 8, 9, 10, 'J', 'Q', 'K', 'A']
random.shuffle(l)   # 随机打乱容器类型中的诸多元素
print(l)



# 搜狗公司笔试题
# 随机验证码可以是由 数字 小写字母 大小写字母 任意组合
# 编写能够产生五位数的随机验证码

def func(n):
    # 由于需要产生五位 每一位的操作都是一样的 所以肯定需要使用循环
    for i in range(n):
        # 随机产生一个数字
        random_int = str(random.randint(1, 9))
        # 随机产生一个大写字母
        random_upper = chr(random.randint(65, 90))
        # 随机产生一个小写字母
        random_lower = chr(random.randint(97, 122))
        # 随机选取一个
        res = random.choice([random_int, random_upper, random_lower])
        # 拼接到字符串中
        print(res, end='')
        
func(7)
        

  

 

 

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视频合集')
4.获取当前文件所在的路径(可以嵌套 则为上一层路径)
BASE_DIR = 	os.path.dirname(__file__)
5.路径拼接(******) 能够自动识别不同操作系统分隔符问题
movie_dir = os.path.join(BASE_DIR,'老师教学视频')
6.列举出指定路径下的文件名称(任意类型文件名称
os.listdir
练习:
data_mover_list = os,listdir('D:\py20\day21\老师教学视频')
while True:
    for i,j in enumerate(data_movie_list):
        print(i + 1, j)  # i是1—6 序号,j是文件内的各个文件的名称
    choice = input('请选择你想要看的文件编号》》》:')
    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'))                                    

  

 

sys模块

# 主要与python解释器打交道

import sys


print(sys.path)     系统路径,到模块用到(绝对导入
print(sys.version)   当前解释器版本
print(sys.platform)   win32,平台版本
print(sys.argv)  # 获取当前执行文件的绝对路径
try:
	username = sys.argv[1]
	passwoed = 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类型的转换
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))
将字典取出来
with open(r'a.txt', 'r', encoding='utf8')as f1:
    data = f.read()
print(dict(data))  # 转换不来,还是字符串

将字典d写入文件
data = json.dumps(d)
with open(r'a.txt', 'w', encoding='utf8')as f:
    f.write(data)
	data = json.dumps(d)
with open(r'a.txt', 'r', encoding='utf8')as f1:
    res = f1.read()
    res1 = json.loads(res)
    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 f1:
    data = json.loads(f1)  等于上方 data = f.read()和res1 = json.loads(data)
    print(data)
    
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
"""

  

 

 

posted @ 2021-11-26 20:05  殷国敏  阅读(45)  评论(0)    收藏  举报