ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

海賊王になる男です。常用模块之random,os,sys,json,subprocess

2021-11-26 18:04:07  阅读:326  来源: 互联网

标签:random 海賊 subprocess json 模块 print path os


目录

今日内容概要

  • random模块
  • os模块
  • sys模块
  • 序列化模块
  • subprocess模块

image

内容详细

random随机数模块

import random

# 随机产生一个0-1之间的小数
print(random.random())  # 0.10115890219539025

# 随机产生一个1-6之间的整数(掷骰子)
print(random.randint(1, 6))  # 4

# 随机产生一个1-6之间的小数
print(random.uniform(1,6))  # 2.887746768640004

# 随机抽取一个样板
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)  # [3, 2, 5, 'J', 8, 'Q', 4, 7, 'A', 10, 'K', 9, 6]


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

def get_code(n):
    # 提前定义一个存储验证码的变量
    code = ''
    # 由于需要产生五位 每一位的操作都是一样的 所以肯定需要使用循环
    for i in range(n):
        # 随机产生一个数字
        random_int = str(random.randint(0, 9))
        # 随机产生一个大写字母
        random_upper = chr(random.randint(65, 90))  # chr 把数字转按照ASCLL码表转成对应的字母
        # 随机产生一个小写字母
        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)  # sd5g7 PLc1lt32wm 7WcW301G

image

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__)
print(BASE_DIR)
BASE_DIR = os.path.dirname(os.path.dirname(__file__))  # 返回上一层

# 5.路径拼接(******) 能够自动识别不同操作系统分隔符问题
movie_dir = os.path.join(BASE_DIR, '老师教学视频')

# 6.列举出指定路径下的文件名称(任意类型文件)
data_movie_list = os.listdir('E:/每日练习文件/老师教学视频')
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'))  
print(os.path.exists('老师教学视频'))  
print(os.path.exists('...')) 

# 12.判断当前路径是否是文件
print(os.path.isfile('老师教学视频'))  
print(os.path.isfile('...'))  

# 13.判断当前路径是否是文件夹
print(os.path.isdir('01.py'))  # False
print(os.path.isdir('老师教学视频'))  # True

# 14.获取文件大小(字节数)
print(os.path.getsize(r'001.py'))

image

sys模块

import sys
# 主要与python解释器打交道

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('请输入用户名和密码')

image

序列化模块(json)

import json
# json格式数据 用于跨语言传输

d = {'username': 'jason', 'pwd': 123}

# 1.将python其他数据转换成json格式字符串(序列化)
res = json.dumps(d)  # python中的字典转换成json格式字符串
print(res, type(res))  # {"username": "jason", "pwd": 123} <class 'str'>

# 2.将json格式字符串转成当前语言对应的某个数据类型(反序列化)
res1 = json.loads(res)  # 转回python语言中的字典类型
print(res1, type(res1))  # {'username': 'jason', 'pwd': 123} <class 'dict'>

bytes_data = b'{"username": "jason", "pwd": 123}'
bytes_str = bytes_data.decode('utf8')  # 先把其他语言的数据解码成json格式字符串
bytes_dict = json.loads(bytes_str)  # json格式字符串转成python语言的字典类型
print(bytes_dict, type(bytes_dict))  # {'username': 'jason', 'pwd': 123} <class 'dict'>

"""
简单理解:
	序列化就是将其他数据类型转成字符串的过程
		json.dumps()
	
	反序列化就是将字符串类型转成其他数据类型
		json.loads()
"""

d = {'username': 'jason', 'pwd': 123}

# 将字典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写入文件(通过json模块转换实现)
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)  # 将json格式字符串转成当前语言的字典数据类型(反序列化)
print(res1, type(res1))  # {'username': 'jason', 'pwd': 123} <class 'dict'>


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


# 文本内容含有汉字 需要指定解释器不操作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]}

"""
不是所有的数据类型都支持序列化
json.JSONEncoder 查看支持的数据类型
"""

image

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

image

标签:random,海賊,subprocess,json,模块,print,path,os
来源: https://www.cnblogs.com/jgx0/p/15608020.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有