内置模块2

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(['江苏省','安徽省','山东省','湖南省','海南省','广东省'],1))#随机抽取指定样本量


l = [2,3,4,5,6,7,8,9,10,'j','q','k','a']

"""
random.shuffle(l) #随机打乱容器类型中的诸多元素

""""
print(l)


"""搜狗公司面试题"""
随机验证码可以是由 数字 小写字母 大小写字母 任意组合
编写能够产生五位数的随机验证码
"""五位 每位都可以是三种情况之一"""

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、创建单级目录(文件夹)

os.mkdir(r'oldboy视频')

os.mkdir(r'oldboy视频合集\r鸡哥视频') # 报错


2、创建多级目录(文件夹)

os.makedirs(r'oldboy精品\鸡哥作品\金牌班')


3、删除空目录(文件夹)

os.rmdir(r'oldboy合集')

os.removedirs(r'oldboy合集')


4、获取当前文件所在的路径(可以嵌套 则为上一层路径)

BASE_DIR = os.path.dirname(__file__)


5、路径拼接(******)能够自动识别不同操作系分隔符问题

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

序列化模块

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

万元系数

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值