Python常用模块学习 - time、datetime、os、sys、random、shutil

2024-01-04 22:58

本文主要是介绍Python常用模块学习 - time、datetime、os、sys、random、shutil,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、time模块:与时间相关功能

二、datetime 模块:时间处理模块

三、random:随机数模块

3-1 random - 生成随机整形和字符,指定位数

3-1 random + string - 生产随机整形+字符,随机位数

四、sys 模块:python解释器系统相关模块,多用于脚本编写

4-1 sys模块实例 - 打印进度条

五、shutil 模块:简化文件操作(文件的高级操作)

5-1  压缩包处理 - zipfile 压缩、解压缩

5-2 压缩包处理 -  tarfile 压缩、解压缩

六、os模块:与操作系统进行交互的接口模块

6-1 os 下常用函数

6-2 os.path 常用函数

6-3 os 的路径处理

6-4 os.path 获取文件元数据
————————————————
版权声明:本文为CSDN博主「林司逾」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_33961117/article/details/82426287

一、time模块:与时间相关功能
'''
time模块:与时间相关的功能三种时间类型:1.时间戳(timestamp):从1970-01-01 到现在的秒数,用于取时间差time.time():用来计算时间间隔,返回浮点型2.本地时间(localtime):计算机当前所在位置的时间time.localtime():返回结构化时间3.世界协调时间(UTC)time.gmtime():返回结构化时间常用方法总结:1.时间戳:time.time()应用:用来计算时间间隔2.结构化时间:time.localtime() time.gtime()应用:1.单独获取当前时间的任意部分2.用来时间戳与格式化输出时间之间的转换3.格式化的字符串形式:time.strftime('%Y-%m-%d')应用:方便的取出格式化字符串形式的时间,用来显示datetime模块 vs time模块1.日期计算比time模块方便datetime.datetime.now()+datetime.timedelta(days=3)2.时间戳转换成字符串日期时间datetime.datetime.fromtimestamp(123123123)
'''import timeprint(time.time())
# 1536136291.5491552print(time.strftime('%Y-%m-%d %X'))
# 2018-09-05 16:31:31print(time.localtime())
# time.struct_time(tm_year=2018, tm_mon=9, tm_mday=5, tm_hour=16, tm_min=31, tm_sec=31, tm_wday=2, tm_yday=248, tm_isdst=0)print(time.gmtime())
# time.struct_time(tm_year=2018, tm_mon=9, tm_mday=5, tm_hour=8, tm_min=31, tm_sec=31, tm_wday=2, tm_yday=248, tm_isdst=0)# 格式化输出日期
print(time.strftime('%Y-%m-%d %X'))
# 2018-09-05 16:31:31# 将格式化字符串的时间转换为结构化时间
print(time.strptime("30 Nov 00", "%d %b %y"))
# time.struct_time(tm_year=2000, tm_mon=11, tm_mday=30, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=3, tm_yday=335, tm_isdst=-1)# 时间戳转结构化,参数为秒数,即1970年01-01过参数秒的结构化时间输出
print(time.localtime(10))
# time.struct_time(tm_year=1970, tm_mon=1, tm_mday=1, tm_hour=8, tm_min=0, tm_sec=10, tm_wday=3, tm_yday=1, tm_isdst=0)# 结构化转时间戳
print(time.mktime(time.localtime()))
# 1536136291.0# 当前进程睡眠一段时间,单位为秒 time.sleep()
time.sleep(2)# 返回 星期英文简写 月 日 时间 年(Thu Aug  9 09:11:42 2018)
print(time.asctime())
# Wed Sep  5 16:31:33 2018
print(time.ctime())
# Wed Sep  5 16:31:33 2018'''
%y 两位数的年份表示(00-99)
%Y 四位数的年份表示(000-9999)
%M 分钟数(00=59)
%m 月份(01-12)
%D 08/09/18 本地相应的日期表示
%d 月内中的一天(0-31)
%x 本地相应的日期表示
%X 本地相应的时间表示
%H 24小时制小时数(0-23)
%I 12小时制小时数(01-12)
%S 秒(00-59)
%a 本地简化星期名称
%A 本地完整星期名称
%b 本地简化的月份名称
%B 本地完整的月份名称
%c 本地相应的日期表示和时间表示
%j 年内的一天(001-366)
%p 本地A.M.或P.M.的等价符
%U 一年中的星期数(00-53)星期天为星期的开始
%w 星期(0-6),星期天为星期的开始
%W 一年中的星期数(00-53)星期一为星期的开始
%Z 当前时区的名称
%% %号本身
'''
二、datetime 模块:时间处理模块
# 比time方便清晰的时间计算。例:显示三天后的时间格式化输出
import datetime# # 获取时间 获取当时时间,返回格式化字符时间
print(datetime.datetime.now())
# >>> 2018-09-05 16:37:11.811998
print(datetime.datetime.today())
# >>> 2018-09-05 16:37:11.811998
#
# # 单独获取某个时间 年 月
d = datetime.datetime.now()
print(d.year)  # >>> 2018
print(d.month)  # >>> 9
#
# # 将int转或成格式时间
d1 = datetime.datetime(2018, 8, 9, 10)
print(d1)  # >>> 2018-08-09 10:00:00# 计算两个时间的差值 只能- 不能+
print(d - d1)  # >>>27 days, 6:37:11.811998# 替换某个时间
print(d.replace(year=2020))  # >>> 2020-09-05 16:37:11.811998# 表示时间差的模块 timedelta
d2 = datetime.timedelta(days=1)
d3 = datetime.timedelta(weeks=1)
print(d2)  # 1 day, 0:00:00
print(d3 - d2)  # 6 days, 0:00:00
# timedelta 时间差可以和一个datetime 进行加减
print(d + d3)  # 2018-09-12 16:39:23.733509
a = datetime.datetime.now() + datetime.timedelta(days=3)
print(a)  # 2018-09-08 16:39:23.733509b = datetime.datetime.fromtimestamp(123123123)
# 时间戳转换成字符串日期时间
print(b)  # 1973-11-26 08:52:03
三、random:随机数模块
import random# 0-1随机浮点,不包含1
print(random.random())
# 0.5685792329553742# a-b 随机整数,包含头尾
print(random.randint(1, 3))  # 3# a-b 随机整数,不包尾
print(random.randrange(1, 3))  # 2# 容器随机元素,包头尾
print(random.choice([1, 2, 3]))  # 2# 随机从容器中取值,取X个值,包头尾
print(random.sample([1, 2, 3], 2))  # [3, 2]# 打乱可变容器的元素顺序
l = [1, 2, 3, 4, 5, ]
random.shuffle(l)
print(l)  # [5, 2, 1, 3, 4]# a-b取浮点数,不包头尾
print(random.uniform(1, 2))  # 1.5748282541280614
3-1 random - 生成随机整形和字符,指定位数
import randomdef veri_code(i):res = ''for j in range(i):num = str(random.randint(0, 9))c = chr(random.randint(65, 90))s = random.choice([num, c])res += sreturn resprint(veri_code(4))
# 2D1A
3-1 random + string - 生产随机整形+字符,随机位数
import random,string# 随机生成5-15位数的字符串
range_token = ''.join(random.sample(string.ascii_letters + string.digits, random.randint(5, 15)))
# 1LDC5G四、sys 模块:python解释器系统相关模块,多用于脚本编写
'''
sys python解释器系统相关模块,多用于脚本的编写1 sys.argv           命令行参数List,第一个元素是程序本身路径2 sys.exit(n)        退出程序,正常退出时exit(0)3 sys.version        获取Python解释程序的版本信息4 sys.maxint         最大的Int值5 sys.path           返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值6 sys.platform       返回操作系统平台名称
'''
4-1 sys模块实例 - 打印进度条
import time# print(("%%-%ds" %(30)) % '*')def progress(percent, width=30):# print(('\r[%% -%ss]'% width)%('*'* int(percent * width)),end='')if percent > 1:percent = 1str = ('\r[%% -%ss]' % width) % ('*' * int(percent * width))print(str + '%d%%' % (percent * 100), end='')# progress(0.5)file_size = 1024
get_size = 0
while get_size < file_size:time.sleep(0.5)  # 模拟数据的网络延迟get_size += 100p = get_size / file_size# print(p)progress(p)五、shutil 模块:简化文件操作(文件的高级操作)
import shutil# shutil.copyfileobj(fsrc, fdst[, length])
# 将文件内容拷贝到另一个文件中
shutil.copyfileobj(open('old.xml', 'r'), open('new.xml', 'w'))# shutil.copyfile(src, dst) 拷贝文件
shutil.copyfile('f1.log', 'f2.log')  # 目标文件无需存在# shutil.copymode(src,dst) 仅拷贝权限。(内容,组,用户都不变)
shutil.copymode('f1.log', 'f2.log')  # 目标文件必须存在# shutil.copystat() 拷贝状态信息 包括:mode bits, atime, mtime, flags
shutil.copystat('f1.log', 'f2.log')  # 目标文件必须存在# shutil.copy() 拷贝文件和权限
shutil.copy('f1.log', 'f2.log')# shutil.copy2()拷贝文件和状态信息
shutil.copy2('f1.log', 'f2.log')# shutil.ignore_patterns(*patterns) 无视指定特点的文件
# shutil.copytree(src, dst, symlinks=False, ignore=None) (源文件,目标文件,硬连接,忽略)
# 递归的去拷贝文件夹
shutil.copytree('folder1', 'folder2', ignore=shutil.ignore_patterns('*.pyc', 'tmp*'))# 目标目录不能存在,注意对folder2目录父级目录要有可写权限,ignore的意思是排除
shutil.copytree('f1', 'f2', symlinks=True, ignore=shutil.ignore_patterns('*.pyc', 'tmp*'))
# 通常的拷贝都把软连接拷贝成硬链接,即对待软连接来说,创建新的文件# shutil.rmtree(path) 递归的去删除文件
shutil.rmtree('folder1')# shutil.move(src, dst)递归的去移动文件 同文件夹内的重命名,更改路径
shutil.move('folder1', 'folder3')# shutil.make_archive(base_name, format,...)  创建压缩包并返回文件路径,仅限:zip、tar
# /data下的文件打包放置 /tmp/目录
ret = shutil.make_archive("/tmp/data_bak", 'gztar', root_dir='/data')
5-1  压缩包处理 - zipfile 压缩、解压缩
# zipfile压缩解压缩
import zipfile# 压缩
z = zipfile.ZipFile('laxi.zip', 'w')  # 指定压缩包名,准备写入文件
z.write('a.log')
z.write('data.data')  # 写入文件z.close()
# 解压
z = zipfile.ZipFile('laxi.zip', 'r')  # 指定压缩包名,准备读取文件
z.extractall(path='.')  # 指定解压路径为'.',即当前
z.close()
5-2 压缩包处理 -  tarfile 压缩、解压缩
# tarfile压缩解压缩
import tarfile# 压缩
t = tarfile.open('/tmp/egon.tar', 'w')  # 指定压缩包名,准备写入文件
t.add('/test1/a.py', arcname='a.bak')  # arcname 指定入包后的名字
t.add('/test1/b.py', arcname='b.bak')  # 指定路径写入文件
t.close()# 解压
t = tarfile.open('/tmp/egon.tar', 'r')  # 指定压缩包名,准备读取文件
t.extractall('/egon')  # 指定解压路径
t.close()六、os模块:与操作系统进行交互的接口模块
os 官方文档菜鸟教程 - os菜鸟教程 - os.path6-1 os 下常用函数
os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname") 改变当前脚本工作目录;相当于shell下cd
os.curdir 返回当前目录: ('.')
os.pardir 获取当前目录的父目录字符串名:('..')
os.makedirs('dirname1/dirname2') 可生成多层递归目录
os.removedirs('dirname1') 若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
os.mkdir('dirname') 生成单级目录;相当于shell中mkdir dirname
os.rmdir('dirname') 删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
os.listdir('dirname') 列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
os.remove() 删除一个文件
os.rename("oldname","newname") 重命名文件/目录
os.stat('path/filename') 获取文件/目录信息
os.sep 输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/"
os.linesep 输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n"
os.pathsep 输出用于分割文件路径的字符串 win下为;,Linux下为:
os.name 输出字符串指示当前使用平台。win->'nt'; Linux->'posix'
os.system("bash command") 运行shell命令,直接显示
os.environ 获取系统环境变量
6-2 os.path 常用函数
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的大小
os.path.normpath(path) 规范path字符串形式(规范文件路径)
6-3 os 的路径处理
#方式一:推荐使用
import os,sys
possible_topdir = os.path.normpath(os.path.join(os.path.abspath(__file__),os.pardir, #上一级os.pardir,os.pardir))
# 将路径载入环境变量中
sys.path.insert(0,possible_topdir)#方式二:不推荐使用
path = os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__)))) # 返回项目文件夹
6-4 os.path 获取文件元数据
import os
import timefile='/root/runoob.txt' # 文件路径os.path.getsize(file) # 输出文件大小(字节为单位)
# 3669
os.path.getatime(file) # 输出最近访问时间
# 1539052805.5735736
os.path.getctime(file) # 输出文件创建时间
# 1539052805.5735736
os.path.getmtime(file) # 输出最近修改时间
# 1539052805.5735736
time.gmtime(os.path.getmtime(file)) # 以struct_time形式输出最近修改时间
# time.struct_time(tm_year=2018, tm_mon=10, tm_mday=9, tm_hour=2, tm_min=40, tm_sec=5, tm_wday=1, tm_yday=282, tm_isdst=0)
time.ctime(os.path.getmtime(file))
# 'Wed Apr 28 13:10:34 2010'
os.path.normpath(file) # 规范path字符串形式————————————————
版权声明:本文为CSDN博主「林司逾」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_33961117/article/details/82426287

 

这篇关于Python常用模块学习 - time、datetime、os、sys、random、shutil的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/570868

相关文章

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

Python运行中频繁出现Restart提示的解决办法

《Python运行中频繁出现Restart提示的解决办法》在编程的世界里,遇到各种奇怪的问题是家常便饭,但是,当你的Python程序在运行过程中频繁出现“Restart”提示时,这可能不仅仅是令人头疼... 目录问题描述代码示例无限循环递归调用内存泄漏解决方案1. 检查代码逻辑无限循环递归调用内存泄漏2.

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

Python如何自动生成环境依赖包requirements

《Python如何自动生成环境依赖包requirements》:本文主要介绍Python如何自动生成环境依赖包requirements问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录生成当前 python 环境 安装的所有依赖包1、命令2、常见问题只生成当前 项目 的所有依赖包1、

如何将Python彻底卸载的三种方法

《如何将Python彻底卸载的三种方法》通常我们在一些软件的使用上有碰壁,第一反应就是卸载重装,所以有小伙伴就问我Python怎么卸载才能彻底卸载干净,今天这篇文章,小编就来教大家如何彻底卸载Pyth... 目录软件卸载①方法:②方法:③方法:清理相关文件夹软件卸载①方法:首先,在安装python时,下

python uv包管理小结

《pythonuv包管理小结》uv是一个高性能的Python包管理工具,它不仅能够高效地处理包管理和依赖解析,还提供了对Python版本管理的支持,本文主要介绍了pythonuv包管理小结,具有一... 目录安装 uv使用 uv 管理 python 版本安装指定版本的 Python查看已安装的 Python