03. 常用模块(二)time, datetime, random, os, sys, subprocess模块

一、时间模块time与datetime模块

1.1 python中表示时间的三种格式:

(1)时间戳(timestamp):表示的是从1970年1月1日00:00:00开始按秒计算的偏移量(float类型)
(2)格式化时间字符串(format string)
(3)结构化时间(struct_time):struct_time元组共有9个元素共九个元素:(年,月,日,时,分,秒,一年中第几周,一年中第几天,夏令时)

时间模块使用语法:

import time

print(time.time())  # 1596091929.4123921
print(time.strftime("%Y-%m-%d %H-%M-%S"))  # 2020-07-30 14-52-09
print(time.localtime())  # 本地时区的结构化时间time.struct_time(tm_year=2020, tm_mon=7, tm_mday=30, tm_hour=14, tm_min=52, tm_sec=9, tm_wday=3, tm_yday=212, tm_isdst=0)
print(time.gmtime())  # UTC时区的结构化时间time.struct_time(tm_year=2020, tm_mon=7, tm_mday=30, tm_hour=6, tm_min=52, tm_sec=9, tm_wday=3, tm_yday=212, tm_isdst=0)

1.2 三种时间格式之间转换的方式示意图:

三种时间格式转换的工具示意图
可以看出:格式化的字符串时间与时间戳之间不可以直接转换
如将时间戳转换成结构化时间:

sec = 1596092420.1442552
print(time.localtime(sec))

1.3 asctime、ctime

在这里插入图片描述
time.asctime([t]) 会将一个表示时间的元组或者struct_time表示成这种形式:“Thu Jul 30 15:11:38 2020”
没有参数就默认将time.localtime()传入

import time

print(time.asctime())

time.ctime([secs])可以将一个时间戳转化成time.asctime()的形式,没有参数的haul就会默认将time.time()传入

import time

print(time.ctime())  # Thu Jul 30 15:20:09 2020

1.4 datetime模块

可以做时间上的加减

import datetime

print(datetime.datetime())  # 2020-07-30 15:24:46.523930
print(datetime.datetime.now() + datetime.timedelta(-3))  #当前时间-3天
print(datetime.datetime.now() + datetime.timedelta(hours=3))  #当前时间+3小时
print(datetime.datetime.now() + datetime.timedelta(minutes=30))  #当前时间+30分
print(datetime.datetime.now().replace(year=1999))  # 替换时间的年份1999-07-30 15:40:23.282765

二、random模块

2.1 常用的random用法

import time 

print(random.random())  # 随机取(0,1)之间的小数
print(random.randint(1,3))  # 随机取[1,3]之间的整数
print(random.randrange(1,3))  # 随机取[1,3)之间的整数
print(random.choice([1,2,3,4]))  # 从列表中随机取一个数
print(random.sample([1,2,3,4]))  # 列表中随机取2个元素组合
print(random.uniform(1,3))  # 随机取(1,3)之间的小数

l1 = [1,2,4,45,5]
random.shuffle(l1)   # 打乱l1的顺序

应用实例:随机生成一个六位验证码(数字加小写字母组合)

import random
def make_code(n=6):
	res = ''
	for i in range(n):
		s1 = chr(random.randint(97,122))
		s2 = str(random.randint(0,9))
		res += random.choice([s1,s2])
	return res
	
print(make_code(6))

三、os模块

os模块是与操作系统交互的一个接口

3.1 常用操作

os.getcwd()  # 获取当前工作目录,即当前脚本工作的目录路径
os.chdir("dirname")  # 改变当前脚本的工作目录
os.curdir  # 返回当前目录:(".")
os.pardir  # 获取当前目录的父目录字符串名:('..')
os.makedirs('dirname1/dirname')  # 可生成多层递归目录
os.removedirs('dirname1')  # 若目录为空,则删除,并递归到上一级目录,为空则删,以此类推
os.mkdir('dirname')  # 生成单级目录
os.rmdir('dirname')  # 删除单级空目录,不为空就无法删除
os.listdir('dirname')  # 列出指定 目录下的所有文件和子目录,包括隐藏文件,以列表的方式返回
os.remove()  # 删除一个文件
os.rename('oldname','newname')  # 重命名
os.stat('path/filename')  # 获取文件/目录信息
os.sep  # 输出操作系统特定的路径分隔符
os.linesep  # 输出当前平台使用的行终止符
os.pathsep  # 输出用于分割文件路径的字符串(win下为;,Linux下为:)
os.name  # 输出字符串指示当前使用平台
os.system("bash command")  运行shell命令,直接显示
os.environ  获取系统环境变量
os.path.abspath(path)  返回path规范化的绝对路径
os.path.split(path)  将path分割成目录和文件名二元组返回
os.path.dirname(path)  返回path的目录。其实就是os.path.split(path)的第一个元素
os.path.basename(path)  返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素
os.path.exists(path)  如果path存在,返回True;如果path不存在,返回False
os.path.isabs(path)  如果path是绝对路径,返回True
os.path.isfile(path)  如果path是一个存在的文件,返回True。否则返回False
os.path.isdir(path)  如果path是一个存在的目录,则返回True。否则返回False
os.path.join(path1[, path2[, ...]])  将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
os.path.getatime(path)  返回path所指向的文件或者目录的最后存取时间
os.path.getmtime(path)  返回path所指向的文件或者目录的最后修改时间
os.path.getsize(path) 返回path的大小

3.2 路径处理方式

(1)

import os, sys
base_path = os.path.normpath(os.path.join(
	os.path.abspath(__file__),
	'..',
	'..',
	))
sys.path.insert(0, base_path)

(2)

import os 
base_path = os.path.dirname(os.path.dirname(__file__))

四、sys模块

sys.srgv  # 命令行参数list,第一个元素是程序本身路径
sys.exit(n)  # 退出程序,正常退出时用exit(0)
sys.version  # 获取python解释器程序的版本信息
sys.maxint  # 最大的int值
sys.path  # 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值
sys.platform  # 返回操作系统平台名称

示例:编写可以在命令行界面运行的copy程序,要求 运行方式为:
python “程序路径” “文件位置” “复制位置”
使用sys.argv来接收三个路径

import sys

src_file = sys.argv[1]  # 文件位置
dst_file = sys.argv[2]  # 复制位置
with open(src_file, 'rb') as src_f,open(dst_file, 'wb') as dst-f:
	for line in src_f:
		dst_f.write(line)

五、subprocess模块

import subprocess

obj = subprocess.Popen('didfr', shell=True,
                       stdout=subprocess.PIPE,
                       stderr=subprocess.PIPE
                       )
res1 = obj.stdout.read()
res2 = obj.stderr.read()
print(res1.decode('gbk'))
print(res2.decode('gbk'))  # 'didfr' 不是内部或外部命令,也不是可运行的程序或批处理文件。

res1、res2分别用来接受正确指令和错误指令运行的结果

六、打印进度条

代码:

def progress(percent, width=50):
    if percent > 1:
        percent = 1
    print("\r[%-50s] %d%%" % ('#' * int(50 * percent), int(100 * percent)), end='')


total_size = 1025  # 文件大小
recv_size = 0
while recv_size < total_size:
    time.sleep(0.3)  % 模拟下载时间
    recv_size += 1024  # 每次下载1024
    percent = recv_size / total_size
    progress(percent)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值