一、模块、包的概念
模块就是一个包含所有你定义的函数和变量的文件,其后缀名是.py。
模块可以被别的程序引入,以使用该模块中的函数等功能。这也是使用 python 标准库的方法。
什么是包?
包,package本质就是一个文件夹,和文件夹不一样的是它有一个__init__.py文件,包是从逻辑上来组织模块的,也就是说它是用来存放模块的,如果你想导入其他目录下的模块,那么这个目录必须是一个包才可以导入
二、导入模块
模块分为:
标准模块:Python内置模块
第三方模块:开源模块
自己开发的模块:自己写的模块
为什么需要导入模块?打个比方如果你想在一个A模块中去调用B模块的方法,这个时候就需要去导入B模块其次才能使用B模块中封装的函数方法。导入模块的本质就是把python文件拿过来执行一次。
(使用包中的模块需要在__init__.py文件中from . import xxx)
模块大导入方法为import函数,语法格式如下:
importmodule1[,module2[,...moduleN]
实例
三、random标准模块
random.randint----随机产生一个整数
1 import random #导入模块
2 print(random.randint(1,100)) #随机在1-100之间产生一个整数
random.uniform----随机产生一个小数
importrandomprint(random.uniform(1,1000)) #随机产生一个1-1000之间的小数
random.choice----随机选择1个元素(可以循环的都可以取值)
importrandom
stu= ['1','2','3','4','5','6']print(random.choice(stu)) #随机选择一个元素,choice只要是可以循环的都可以取值
random.sample----随机选择N个元素(可以循环的都可以取值)
importrandom
stu= ['1','2','3','4','5','6']print(random.sample(stu,2)) #随机取N个值
random.random----随机生成的一个实数,它在[0,1)范围内
importrandomprint(random.random())
random.randrange----指定范围生成一个随机整数
importrandomprint(random.randrange(1,100)) #生成一个1到100的随机整数
print( random.randrange(1,100,5) ) #生成一个1到100的间隔为5的随机整数
random.shuffle----洗牌,将原顺序打乱
importrandom
stu= ['1','2','3','4','5','6']print(random.shuffle(stu)) #洗牌,打乱顺序,无返回值;只能传入list
四、time、datetime模块
两个模块都是对时间进行相关的操作;时间戳,即从计算机诞生到现在过了多少时间。
time和datetime模块主要用于操作时间
time.time----获取当前的时间戳
time.sleep()----设置休眠时间,单位为秒
time.gmtime()----把时间戳转换成时间元组,如果不传的话,默认取标准时区的时间戳
time.strftime()----将时间元组转换成格式化输出的字符串,如果时间不传,默认取当前时间的值
time.mktime()----把时间元组转换成时间戳
time.localtime()----把时间戳转换成时间元组,如果不传的话,默认取当前时区的时间戳
time.asctime()----时间元组转换成格式化时间
time.ctime())----时间戳转换成格式化时间
time.timezone()----和标准时间相差的时间,单位是s
importtimeprint(time.time()) #获取当前的时间戳
time.sleep(1) #休眠5秒,继续执行程序
print(time.gmtime()) #把时间戳转换成时间元组,如果不传的话,默认取标准时区的时间戳
print(time.strftime("%Y %m %d %H:%M:%S"))#将时间元组转换成格式化输出的字符串
print(time.strptime("20160204 191919","%Y%m%d %H%M%S"))#将格式化的时间转换成时间元组
print(time.mktime(time.gmtime())) #把时间元组转换成时间戳
print(time.localtime()) #把时间戳转换成时间元组,如果不传的话,默认取当前时区的时间戳
print(time.asctime())#时间元组转换成格式化时间
print(time.ctime())#时间戳转换成格式化时间
print(time.timezone)#和标准时间相差的时间,单位是s
说明:如果想把时间戳转换成格式化好的时间,或者反过来,把格式化好的时间转换成时间戳;则必须将其先转换成时间元祖
例如:把格式化时间修改1、先把格式化好的时间转成时间元祖2、然后时间元祖在转成时间戳3、时间=1992-01-03res= time.strptime('1992-01-03 19:23:59','%Y-%m-%d %H:%M:%S')print(res) #把格式化好的时间转换成时间元祖
print(time.mktime(res)) #把时间元组转换成时间戳
运行结果:694437839.0
格式化好的时间转换时间戳的方法:def str_to_timestamp(time_str=None,format='%Y%m%d%H%M%S'):'''格式化好的时间转时间戳,如果不传参数返回当前时间'''
iftime_str:
time_tuple= time.strptime(time_str,format) #把格式化好的时间转成时间元组
timestamp = time.mktime(time_tuple) #把时间元组转成时间戳
else:
timestamp= time.time() #获取当前的时间戳,# print(time.time()) #获取当前的时间戳,精确到毫秒,有小数点,如果不想要 转换成int类型即可
returnint(timestamp)print(str_to_timestamp())print(str_to_timestamp('20391123175123'))print(str_to_timestamp('2013-08-09','%Y-%m-%d')) #按传入的格式,而非默认格式运行
运行结果:1585092104
2205654683
1375977600
时间戳转换成格式化好的时间的方法:def timestamp_to_strtime(timestamp = None,format = '%Y-%m-%d %H:%M:%S'):'''1、把时间戳转成格式化好的时间;2、如果不传入时间戳,那么就返回当前的时间'''
iftimestamp:
time_tuple= time.localtime(timestamp) #把时间戳转成时间元组,将时间转换成当前时区的时间
str_time = time.strftime(format,time_tuple) #格式化输出时间元组
else:
str_time= time.strftime(format) # returnstr_time
举个例子:
取3个月后的时间
分析:用当前的时间戳+三个月后的秒数,然后把时间戳转成格式化好的时间
time_str= str_to_timestamp() + (3*30*24*60*60)
res=timestamp_to_strtime(time_str)print('3个月后的时间:',res)
运行结果:
三个月后的时间:2020-06-23 07:27:56说明:这里的月都是按照30天计算的正常情况下应该判断当前月的天数
datime.datetime.now()----获取当前时间并格式化输出
datetime.datetime.today()----获取当前的时间信息
datetime.date.today()----获取当前的日志
importdatetimeprint(datetime.datetime.now()) #获取当前时间并格式化输出
print(datetime.datetime.now() + datetime.timedelta(3)) #计算三天后的时间
print(datetime.datetime.now() + datetime.timedelta(-3)) #三天前的时间
print(datetime.datetime.today()) #获取当前的时间
print(datetime.date.today()) #获取当前的日期
python中时间日期格式化符号:
%y 两位数的年份表示(00-99)
%Y 四位数的年份表示(000-9999)
%m 月份(01-12)
%d 月内中的一天(0-31)
%H 24小时制小时数(0-23)
%I 12小时制小时数(01-12)
%M 分钟数(00=59)
%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)星期一为星期的开始
%x 本地相应的日期表示
%X 本地相应的时间表示
%Z 当前时区的名称
%% %号本身
五、string模块
string.ascii_lowercase----所有的小写字母
string.ascii_uppercase----所有的大写字母
string.digits----0-9整数
string.punctuation----特殊字符
string.ascii_letters----所有的大小写字母
importstringprint(string.ascii_lowercase) #所有的小写字母
print(string.ascii_uppercase) #所有的大写字母
print(string.digits) #0-9整数
print(string.punctuation) #特殊字符
print(string.ascii_letters) #所有的大小字母
运行结果:
abcdefghijklmnopqrstuvwxyz
ABCDEFGHIJKLMNOPQRSTUVWXYZ
0123456789
!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~
abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ
六、OS模块
os.mkdir(path)---创建文件夹
os.makedirs(path)---创建递归文件夹
注意:mkdir和madedirs的区别:mkdir 只能创建单层次的文件夹;创建多层文件夹时会报错;makedirs不仅可以创建单层文件夹还能创建多层文件夹
os.rename(src,dst)---重命名文件或目录,从 src 到 dst
os.remove(path)---删除路径为path的文件。如果path 是一个文件夹,将抛出OSError; 查看下面的rmdir()删除一个 directory。
os.removedirs(path)---递归删除目录。只能删除空文件夹,如果文件夹有内容是删除不了的
os.listdir(path)---返回path指定的文件夹包含的文件或文件夹的名字的列表。如果为空不传参数,则显示当前目录下的文件或文件夹名字列表
os.system(命令)---执行操作系统命令,无法返回执行的结果;
os.popen(命令)---用来执行操作系统的命令,可以返回执行的结果
注意:system和popen命令的区别是,system只是单纯的执行命令并将结果显示给用户,是没有返回值的;而popen命令不仅可以显示命令执行结果,还能将结果的值进行返回
os.walk()---可以将指定文件路径下所有的文件及文件夹找出来
os.getcwd()---获取当前文件的路径
os.chdir()---进入到某一个目录(路径)下
os.path.isdir(path)---判断路径是否为目录
os.path.isfile(path)---判断路径是否为文件
os.paht.exists(path)---判断文件或者文件夹是否存在,存在返回true 不存在返回false
os.path.join(path1[, path2[, ...]])---把目录和文件名合成一个路径
os.path.split(path)---把路径分割成文件路径和 文件名称,返回一个元组;
os.path.dirname(path)---返回文件路径;取文件的父目录
os.path.getsize(path)---返回文件大小,如果文件不存在就返回错误;单位是字节
os.path.getctime(path)---返回文件 path 创建时间
os.path.getmtime(path)---返回最近文件修改时间
os.path.getatime(path)---返回文件/目录最近访问时间(浮点型秒数)
os.mkdir('test') #在当前目录下创建一个test文件夹
os.makedirs(r'test\test1\test11') #在test目录下创建递归文件夹
os.rename('test','study') #将当前目录下的test文件夹修改名称为study
os.remove('aa.txt') #删除当前目录下的aa.txt文件(可以指定目录)
os.removedirs(r'study\test1') #会报错,因为test1下边有文件
print(os.getcwd())#获取当前目录的路径
print(os.chdir(r'G:\\')) #修改文件/文件夹路径
print(os.path.isdir('study')) #判断study是否是文件夹
print(os.path.isfile('OS模块.py')) #判断os模块是否是文件
print(os.path.exists('study')) #判断文件或者文件夹是否存在,存在返回true 不存在返回false
print(os.path.join(r'study\test1','OS模块.py')) #将path和文件组成一个新的路径
print(os.path.split(r'c:\test\test1\a.txt')) #把文件路径分割成文件和文件路径两部分并返回一个元组
print(os.path.dirname(r'c:\test\test1\a.txt')) #返回a.txt文件的父目录路径
print(os.path.getsize('OS模块.py')) #返回os文件的大小
print(os.path.getctime('study')) #显示创建时间
print(os.path.getatime('study')) #显示文件夹最近访问时间
print(os.path.getmtime('study')) #显示文件夹最近修改时间
OS.walk()用法:它可以将指定文件路径下所有的文件及文件夹找出来;
其有三个返回参数;
当前目录
目录下的文件
目录下的文件夹
例1:
res= os.walk('china')for cur_path,dirs,files inres:print('当前目录:',cur_path)print('当前目录下所有文件',files)print('当前目录下所有文件夹:',dirs)print('==========================')
运行结果:
当前目录: china
当前目录下所有文件 []
当前目录下所有文件夹: ['beijing']==========================当前目录: china\beijing
当前目录下所有文件 []
当前目录下所有文件夹: ['haidian']==========================当前目录: china\beijing\haidian
当前目录下所有文件 []
当前目录下所有文件夹: []
例2:插件文件方法deffind_file(path,keyword):'''查找文件路径'''res=os.walk(path)for cur_path,dirs,files inres:for file_name infiles:if keyword infile_name:print('该文件在%s目录下'%cur_path)
find_file('G:\\','fullstack')