微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

第十章 (二)模块补充

目录

random模块

随机数模块
import random
# print(random.random())  # 随机产生弍-之间的小数
# print(random.randint(1,6))  # 随机产生一个1-6之间的整数  掷骰子
# print(random.uniform(1,6))  # 随机产生一个1-6之间的小数
# print(random.choice(['1','2','3','4']))  # 随机抽取一个
# print(random.sample(['1','2','3','4','5'],3))  # ['1', '3', '2'] 随机抽取指定样本量

# l = [2,4,5,6,7,8,9,10,'j','q','k','A']
# random.shuffle(l)  # 随机打乱容器类型中的诸多元素
# print(l)


# 搜狗公司笔试题(15年)
# 随机验证码可以是由 数字,小写字母 大小写字母 任意组合
# 编写能够产生五位数的随机验证码
'''ps:五位 每位都可以是三种情况之一'''

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.列举出指定路径下的文件名称(任意类型文件)
# data_movie_list = os.listdir('D:\py20\day21\老师教学视频')
# 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())

# 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)
# 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('目前只能让你体验一下(游客模式)')

序列化模块

```python
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))
# ValueError: dictionary update sequence element #0 has length 1; 2 is required

# 将字典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  查看支持的数据类型
"""
```

hashlib模块

数据加密

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

日志模块

熟悉日志模块的流程和组成部分	在ATM购物车程序使用

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐