首页 / PYTHON / python 常用模块
python 常用模块
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python 常用模块,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含12341字,纯文字阅读大概需要18分钟。
内容图文
![python 常用模块](/upload/InfoBanner/zyjiaocheng/1323/bdb225a0d0254bd0a9a039389c8a2ca5.jpg)
一 time
time 模块是普通的时间模块
1、time.time( )
? 时间戳:从 1970 到现在经过的秒数
? 作用:用于时间间隔的计算
import time
print(time.time()) #1585531035.687209
2、time.strftime( )
? 按照某种格式显示的时间: 2020-03-30 11:11:11
? 作用:用于展示时间
print(time.strftime(‘%Y-%m-%d %H%M%S‘)) #2020-03-30 091802
print(time.srtftime(‘%Y-%m-%d %X‘)) #2020-03-30 09:18:39
#获取当前的年
print(time.strftime(‘%Y‘)) #2020
3、time.localtime()
结构化时间
? 作用: 用于获取时间的某一部分
res = time.localtime()
print(res)#time.struct_time(tm_year=2020, tm_mon=3, tm_mday=30, tm_hour=9, tm_min=19, tm_sec=49, tm_wday=0, tm_yday=90, tm_isdst=0)
print(res.tm_year) #2020
print(res.tm_yday) #90
补充:
世界标准时间(结构化)与本地之间(东八区)对比
print(time.localtime()) #time.struct_time(tm_year=2020, tm_mon=3, tm_mday=30, tm_hour=15, tm_min=21, tm_sec=44, tm_wday=0, tm_yday=90, tm_isdst=0)
print(time.gmtime()) #time.struct_time(tm_year=2020, tm_mon=3, tm_mday=30, tm_hour=7, tm_min=20, tm_sec=39, tm_wday=0, tm_yday=90, tm_isdst=0)
#本地址时间(采用上海时间)比世界标准时间快了 8 个小时
时间显示格式为:星期 月份 天数 时间 年(通常用于 linux 系统)
import time
print(time.asctime()) #Mon Mar 30 15:46:23 2020
4、时间转换
![技术分享图片](/upload/getfiles/default/2022/10/28/20221028072222096.jpg)
示例:
? 结构化时间 --------------》时间戳
import time
s_time= time.localtime()
print(time.mktime(s_time)) #1585552579.0
? 时间戳--------------》结构化时间
tp_time = time.time()
print(time.localtime(tp_time)) #time.struct_time(tm_year=2020, tm_mon=3, tm_mday=30, tm_hour=15, tm_min=25, tm_sec=15, tm_wday=0, tm_yday=90, tm_isdst=0)
print(time.localtime(333333333)) #time.struct_time(tm_year=1980, tm_mon=7, tm_mday=25, tm_hour=8, tm_min=35, tm_sec=33, tm_wday=4, tm_yday=207, tm_isdst=0)
? 结构化时间--------------》格式化的字符串形式的时间
s_time= time.local()
print(time.strftime(‘%Y-%m-%d %H:%M:%S‘, s_time)) #2020-03-30 15:29:04
#获取年月
print(time.strftime(‘%Y/%m‘)) #2020/03
# 获取年月日
print(time.strftime(‘%Y-%m-%d‘)) #2020-03-30
? 格式化字符串时间转换为------------》结构化时间
print(time.strptime(‘19888-03-03 11:11:11‘, ‘%Y-%m-%d, %H:%M:%S‘))
#time.struct_time(tm_year=1988, tm_mon=3, tm_mday=3, tm_hour=11, tm_min=11, tm_sec=11, tm_wday=3, tm_yday=63, tm_isdst=-1)
必须掌握:format string(格式化时间) <---------->timestamp(时间戳)
格式化时间与时间戳格式不能直接互相转化,需要通过结构化时间
格式化时间 ----------》结构化时间-----------------》时间戳
‘‘‘
‘1988-03-03 11:11:11‘+7
‘‘‘
struct_time = time.strptime(‘1988-03-03 11:11:11‘, ‘%Y-%m-%d, %H:%M%s‘) #格式化时间转换为结构化时间
timestamp = time.mktime(struct_time) +7 * 86400 #结构化时间转换为时间戳 +7
print(timestramp) #573966671.0
时间戳 --------------》结构化时间--------------------》格式化时间
timestamp = time.time() #时间戳
struct_time = time.localtime(timestamp) #时间戳转换为结构时间
res = time.strftime(‘%Y-%m-%d, %X‘, struct_time) #2020-03-30 15:42:39
二 datetime
datetime 模块是基于 time 模块封装的一种比较便利的时间模块
1、获取当前时间
import datetime
print(datetime.datetime.now()) #2020-03-30 15:48:20.298178
#世界时间
print(datetime.datetime.utcnow()) #2020-03-30 07:48:20.298234
# 获取当前年月日
print(datetime.date.today() #2020-03-31
# 获取当前年月日时分秒
print(datetime.datetime.today()) #2020-03-31 00:39:08.038798
2、时间加减计算
日期/时间的计算:
日期时间 = 日期时间 “+” or “-” 时间对象
时间对象 = 日期时间 “+” or “-” 日期时间
print(datetime.datetime.now()) #2020-03-30 09:59:59.554466
#获取三天后的时间
print(datetime.datetime.now() + datetime.timedelta(days=3)) #2020-04-02 09:59:59.554513
#获取一周后的时间
print(datetime.datetime.now() + datetime.timedelta(weeks=1))#2020-04-06 09:59:59.554529
3、时间格式转换
时间戳转换为格式化时间
import datetime
pirint(datetime.datetime.fromtimestamp(333333)) #1970-01-05 04:35:33
时间替换
c_time = datetime.datetime.now()
print(c_time)
print(c_time.replace(minute=3, hour=2)) #时间替换
#结果展示
‘‘‘
2020-03-31 00:23:27.756616
2020-03-31 02:03:27.756616
‘‘‘
三 random
? random:python提供的随机取值模块
1 random.random( ) #(0,1)
? 取大于 0 且小于 1 之间的小数
import random
res = random.random()
#print(res) #0.0013748341683205156
print(res) #0.2427640714095196
2 random.randint(1, 3 ) #[1, 3]
取大于等于 1 且小于等于 3 之间的整数
res = random.randint(1, 3)
#print(res) #2
#print(res) #3
print(res) #1
3 random.randrange(1, 3) #[1, 3)
取大于等于1且小于 3 之间的整数
res = random.randrange(1, 3)
print(res) #1
print(res) #2
4 random.choice([111, ‘aaa‘, [4,5]])
取列表中的一个元素: 1或者23或者[4,5]
res= random.choice([111, ‘aaa‘, [4, 5]]) # 1或者23或者[4,5]
print(res) #[4,5]
5 random.sample([111,‘aaa‘,‘bbb‘, [4,5]])
取列表中两个元素任意组合成列表
res = random.sample([111, ‘aaa‘, ‘bbb‘, [4, 5]])
#print(res) # [‘aaa‘, 111]
print(res) #[111, ‘bbb‘]
6 random.uniform(1, 3) #(1, 3)
取大于 1 小于 3 的小数
res = random.uniform(1, 3)
print(res) #2.913178536016434
7 random.shuffle( 可迭代对象)
打乱可迭代对象中的元素,相当于‘洗牌‘
item = [1,3,5,7,9]
res = random.shuffle(item)
print(res) #[7, 3, 5, 9, 1]
应用:随机验证码
随机验证码是由字母和数字组成
字母范围(A-Z) :随机生成字母:通过随机 ASCII 码数字,然后转换为字母
数字(0-9)
伪代码:
import random
res = ‘‘
for i in range(6):
从 26 个大写字母中随机取出一个 = chr(random.randint(65, 90))
从 10 个数字中随机取出一个 = str(random.randint(0, 9))
随机字符 = ransdom.choice([从26大写字母中随机取出一个,从10个数字中随机取出一个])
res += 随机字符
示例:
import random
def make_code(size_num):
‘‘‘
验证功能
size_num:验证码字符个数
‘‘‘
str1 = ‘‘ #验证码
for i in range(size_num):
#大写字母
str_upper = chr(random.randint(65, 90)) # A-Z
#小写字母
str_lower = chr(random.randint(97, 122)) # a-z
#数字
num = str(random.randint(0, 9)) #0-9
res = random.choice((str_lower, str_upper, num))
str1 += res
return str1
res = make_code(6)
注:在ASCII码中,数字范围:97-122,对应小写字母;数字范围65-90,对应大写字母。
三 os
os 模块是与操作系统交互的一个接口
1、os.listdir(‘文件夹路径‘) 或 os.listdir(‘.‘)
获取某 一个文件夹下所有的子文件以及子文件夹的名字
res = os.list(‘.‘)
print(res) #[‘笔记.txt‘, ‘01 时间模块.py‘, ‘run.py‘, ‘04 sys模块.py‘, ‘02 random模块.py‘, ‘aaa‘, ‘03 os模块.py‘]
2、os.path.getsize(‘文件路径‘)
获取文件大小(单位:字节)
print(__file__) #/Users/tophan/Desktop/代码 2/03 os模块.py
size = os.path.getsize(__file__)
print(size) #187 字节
3、os.remove( )
删除一个文件
4、os.rename(‘oldname‘, ‘newname‘)
重命名文件/目录
5、os.system(‘cmd 命令 ‘)
#查看根目录下的文件目录 应用程序-----》‘ls /‘
os.system(‘ls /‘) #运行 shell 命令 直接显示
6、os.environ
获取系统环境变量,应用软件级别的变量
#添加系统环境变量, 规定:key, value必须都为字符串类型
os.environ[‘aaaaaaaaaa‘]=‘111‘
print(os.environ) #{字典类型}
7、os.path
1、返回文件路径中的目录(即文件所在的文件夹)
print(os.path.dirname(r‘/a/b/c/d.txt‘)) #/a/b/c
2、返回文件路径中的文件名
print(os.path.basename(r‘/a/b/c/d.txt‘)) #d.txt
3、判断文件是否存在
前提:与执行文件是同一级别
如果path 存在,返回 True,否则返回 False
print(os.path.isfile(r‘笔记.txt‘)) #False 没有这个文件
print(os.path.isfile(r‘os 模块.py‘)) #True 文件有
print(os.path.isfile(r‘day22‘)) #False day22为文件夹
print(os.path.isfile(r‘格式化输出.py‘)) #False #不是同一目录下
4、判断文件夹是否存在
前提:与执行文件是同一级别
如果文件存在,返回 True,否则返回 False
print(os.path.isdir(r‘aaa‘)) #False #文件夹不存在
print(os.path.isdir(‘day22‘)) #False #不是同一级别
print(os.path.isdir(‘111‘)) #True
5、os.path.join( )
拼接路径
print(os.path.join(r‘/a/b‘, ‘c.txt‘)) #/a/b/c.txt
print(os.path.join(‘a‘,‘/‘,‘b‘,‘c‘,‘d‘)) #/b/c/d #拼接路径,根目录(/)忽略
6、os.dir.dirname(__ file __)
获取执行文件的上一级目录
BASE_DIR = os.path.dirname(os.path.dirname(__file__))
print(BASE_DIR) #/Users/tophan/2020_python
os.path.normpath(文件) :
? 按..或/ 的数目返回上一级目录
res = os.path.join(
__file__,
‘..‘, ##.. 代表上一级
‘..‘ #.. 代表上一级
)
#规范化路径,如..和/
print(res) #/Users/tophan/2020_python/day22/os 模块.py/../..
BASE_DIR=os.path.normpath(res) #按..或/ 的数目返回上一级目录
print(BASE_DIR) #/Users/tophan/2020_python
了解:
在Linux和Mac平台上,该函数会原样返回path,在windows平台上会将路径中所有字符转换为小写,并将所有斜杠转换为饭斜杠。
>>> os.path.normcase(‘c:/windows\\system32\\‘)
‘c:\\windows\\system32\\‘
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 获取系统环境变量
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的大小
7、pathlib
pathlib:在 python3.5之后推出的一个新的模块
from pathlib import Path
# print(Path(__file__)) #/Users/tophan/2020_python/day22/os 模块.py
res = Path(__file__).parent.parent #返回值是执行文件的上一级的上一级路径
print(res) #/Users/tophan/2020_python
Path(‘文件目录‘ / ‘文件名‘):拼接文件路径
res=Path(‘/a/b/c‘) / ‘d/e.txt‘ #拼接文件路径
print(res) #/a/b/c/d/e.txt
path.resolve() 方法会把一个路径或路径片段的序列解析为一个绝对路径
res=Path(‘/a/b/c‘) / ‘d/e.txt‘
print(res.resolve()) #把一个路径或路的序列解析为一个绝对路径
四 sys
sys模块是与 python 解释器交互的一个接口
1 sys.argv
sys.argv:获取的是解释器后参数值
如:若run.py 文件中有 print(sys.argv),那么在终端输入 python3 run.py a.txt b.txt ,就会打印出解释器后的参数值: [‘run.py‘, ‘a.txt‘, ‘b.txt‘]
具体案例:
通过 终端命令进行拷贝操作
import sys
#sys.argv:获取的是解释器后参数值
print(sys.argv) # 有这步打印操作,终端中才会显示[‘run.py‘, ‘a.txt‘, ‘b.txt‘]
src_file = sys.argv[1] #a.txt, 源文件路径
dst_file = sys.argv[2] #b.txt, 目标文件路径
with open(‘%s‘%src_file, ‘rb‘)as read_f, open(‘%s‘%dst_file, ‘wb‘)as write_f:
for line in read_f:
write_f.write(line)
进度条案例
具备知识:
print(‘[%-50s]‘ %‘#‘) #[# ]
print(‘[%-50s]‘ %‘##‘) #[## ]
print(‘[%-50s]‘ %‘###‘) #[### ]
‘‘‘
指定列表宽度:50
- :右对齐
‘#‘:打印#,不够就用空格填充
‘‘‘
示例:
res = ‘‘
import time
for i in range(50):
res += ‘#‘
time.sleep(0.3)
print(‘\r[%-50s]%d‘%(res, i+1), end=‘‘) #\r:移至行首,即每次循环打印不会再在后面接着打印,都是会跳到行首打印,因此每次都会覆盖掉原来的打印内容,肉眼看起来像动态的进度
结果展示:
[############################################ ]44
[##################################################]50
进度条具体代码:
import time
def progress(percent):
res_str = ‘#‘ * int(percent * 50)
time.sleep(0.01)
print(‘\r[%- 50s] %d%%‘ % (res_str, int(100 * percent)), end=‘‘)
total_size = 333333
recv_size = 0
while recv_size < total_size:
# 未接收字的节数
remaining_size = total_size - recv_size
if remaining_size >= 1024:
# 每次接收的字节数
recv_size += 1024
# 获取接收的数据占总数据多少百分比
else:
recv_size += remaining_size
percent = recv_size / total_size
progress(percent)
五 shutil 模块
高级的 文件、文件夹、压缩包 处理模块
1 shutil.copyfileobj(fsrc, fdst[, length])
将文件内容拷贝到另一个文件中
import shutil
shutil.copyfileobj(open(‘old.xml‘,‘r‘), open(‘new.xml‘, ‘w‘))
2 shutil.copyfile(src, dst)
拷贝文件
shutil.copyfile(‘f1.log‘, ‘f2.log‘) #目标文件无需存在
3 shutil.copymode(src, dst)
仅拷贝权限。内容、组、用户均不变
shutil.copymode(‘f1.log‘, ‘f2.log‘) #目标文件必须存在
4 shutil.copystat(src, dst)
仅拷贝状态的信息,包括:mode bits, atime, mtime, flags
shutil.copystat(‘f1.log‘, ‘f2.log‘) #目标文件必须存在
5 shutil.copy(src, dst)
拷贝文件和权限
import shutil
shutil.copy(‘f1.log‘, ‘f2.log‘)
6 shutil.copy2(src, dst)
拷贝文件和状态信息
import shutil
shutil.copy2(‘f1.log‘, ‘f2.log‘)
7 shutil.ignore_patterns(*patterns)
shutil.copytree(src, dst, symlinks=False, ignore=None)
递归的去拷贝文件夹
import shutil
shutil.copytree(‘folder1‘, ‘folder2‘, ignore=shutil.ignore_patterns(‘*.pyc‘, ‘tmp*‘)) #目标目录不能存在,注意对folder2目录父级目录要有可写权限,ignore的意思是排除
8 shutil.rmtree(path[, ignore_errors[, onerror]])
递归的去删除文件
import shutil
shutil.rmtree(‘folder1‘)
9 shutil.move(src, dst)
递归的去移动文件,它类似mv命令,其实就是重命名。
import shutil
shutil.move(‘folder1‘, ‘folder3‘)
10 shutil.make_archive(base_name, format,...)
创建压缩包并返回文件路径,例如:zip、tar
创建压缩包并返回文件路径,例如:zip、tar
- base_name: 压缩包的文件名,也可以是压缩包的路径。只是文件名时,则保存至当前目录,否则保存至指定路径,
如 data_bak =>保存至当前路径
如:/tmp/data_bak =>保存至/tmp/ - format: 压缩包种类,“zip”, “tar”, “bztar”,“gztar”
- root_dir: 要压缩的文件夹路径(默认当前目录)
- owner: 用户,默认当前用户
- group: 组,默认当前组
- logger: 用于记录日志,通常是logging.Logger对象
#将 /data 下的文件打包放置当前程序目录
import shutil
ret = shutil.make_archive("data_bak", ‘gztar‘, root_dir=‘/data‘)
#将 /data下的文件打包放置 /tmp/目录
import shutil
ret = shutil.make_archive("/tmp/data_bak", ‘gztar‘, root_dir=‘/data‘)
shutil 对压缩包的处理是调用 ZipFile 和 TarFile 两个模块来进行的,详细:
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()
#zipfile压缩解压缩
import tarfile
# 压缩
>>> t=tarfile.open(‘/tmp/egon.tar‘,‘w‘)
>>> t.add(‘/test1/a.py‘,arcname=‘a.bak‘)
>>> t.add(‘/test1/b.py‘,arcname=‘b.bak‘)
>>> t.close()
# 解压
>>> t=tarfile.open(‘/tmp/egon.tar‘,‘r‘)
>>> t.extractall(‘/egon‘)
>>> t.close()
tarfile压缩解压缩
原文:https://www.cnblogs.com/xy-han/p/12602228.html
内容总结
以上是互联网集市为您收集整理的python 常用模块全部内容,希望文章能够帮你解决python 常用模块所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。