python中常用的模块的总结

上传人:沈*** 文档编号:87907988 上传时间:2022-05-10 格式:DOC 页数:11 大小:58.50KB
返回 下载 相关 举报
python中常用的模块的总结_第1页
第1页 / 共11页
python中常用的模块的总结_第2页
第2页 / 共11页
python中常用的模块的总结_第3页
第3页 / 共11页
点击查看更多>>
资源描述
.1、模块和包a.定义:模块用来从逻辑上组织python代码变量,函数,类,逻辑:实现一个功能,本质就是.py结尾的python文件。例如:文件名:test.py,对应的模块名:test包:用来从逻辑上组织模块的,本质就是一个目录必须带有一个_init_.py的文件b导入方法import module_nameimport module_1的本质:是将module_1解释了一遍也就是将module_1中的所有代码复制给了module_1from module_name1 import name本质是将module_name1中的name变量放到当前程序中运行一遍所以调用的时候直接print(name)就可以打印出name变量的值代码例子:自己写的模块,其他程序调用,如下所示:模块module_1.py代码:复制代码1 name = dean2 def say_hello():3 print(hello %s %name)调用模块的python程序main代码如下:切记调用模块的时候只需要import模块名不需要加.pyimport module_1#调用变量print(module_1.name)#调用模块中的方法module_1.say_hello()复制代码这样运行main程序后的结果如下:1 D:python35python.e*e D:/python培训/s14/day5/module_test/main.py2 dean3 hello dean4 5 Process finished with e*it code 0import module_name1,module_name2from module_name import *(这种方法不建议使用)from module_name import logger as log(别名的方法)c.导入模块的本质就是把python文件解释一遍import module_name-module_name.py-module_name.py的路径-sys.path导入包的本质就是执行该包下面的_init_.py关于导入包的一个代码例子:新建一个package_test包,并在该包下面建立一个test1.py的python程序,在package包的同级目录建立一个p_test.py的程序test1的代码如下:1 def test():2 print(int the test1)package_test包下的_init_.py的代码如下:1 #import test1 理论上这样就可以但是在pycharm下测试必须用下面from .import test12 from . import test13 print(in the init)p_test的代码如下:1 import package_test #执行_init_.py2 package_test.test1.test()这样运行p_test的结果:1 D:python35python.e*e D:/python培训/s14/day5/p_test.py2 in the init3 int the test14 5 Process finished with e*it code 0从上述的例子中也可以看出:导入包的时候其实是执行包下的_init_.py程序,所以如果想要调用包下面的python程序需要在包下的_init_.py导入包下面的程序2、模块的分类a标准库b开源模块c自动以模块3、时间模块time与datetimepython中常见的时间表示方法:a. 时间戳时间戳:从1970年1月1日00:00:00到现在为止一共的时间数单位为秒 time.time()1472016249.393169 b. 格式化的时间字符串c. struct_time(元组)相互之间的转换关系如下:1 time.localtime()将时间戳转换为当前时间的元组 time.localtime()time.struct_time(tm_year=2016, tm_mon=8, tm_mday=24, tm_hour=13, tm_min=27, tm_sec=55, tm_wday=2, tm_yday=237, tm_isdst=0) 2 time.gmtime()将时间戳转换为当前时间utc时间的元组 time.gmtime()time.struct_time(tm_year=2016, tm_mon=8, tm_mday=24, tm_hour=5, tm_min=35, tm_sec=43, tm_wday=2, tm_yday=237, tm_isdst=0) 3 time.mktime()可以将struct_time转换成时间戳 * = time.localtime() *time.struct_time(tm_year=2016, tm_mon=8, tm_mday=24, tm_hour=13, tm_min=39, tm_sec=42, tm_wday=2, tm_yday=237, tm_isdst=0) time.mktime(*)1472017182.0 4将struct_time装换成格式化的时间字符串 *time.struct_time(tm_year=2016, tm_mon=8, tm_mday=24, tm_hour=13, tm_min=39, tm_sec=42, tm_wday=2, tm_yday=237, tm_isdst=0) time.strftime(%Y-%m-%d %H:%M:%S,*)2016-08-24 13:39:42 5可以将格式化的时间字符串转换为struct_time time.strptime(2016-08-24 14:05:32,%Y-%m-%d %H:%M:%S)time.struct_time(tm_year=2016, tm_mon=8, tm_mday=24, tm_hour=14, tm_min=5, tm_sec=32, tm_wday=2, tm_yday=237, tm_isdst=-1) 6将struct_time转换成Wed Aug 24 14:22:47 2016这种格式 *time.struct_time(tm_year=2016, tm_mon=8, tm_mday=24, tm_hour=14, tm_min=22, tm_sec=47, tm_wday=2, tm_yday=237, tm_isdst=0) time.asctime(*)Wed Aug 24 14:22:47 2016 7将时间戳装换成Wed Aug 24 14:22:47 2016格式 * = time.time() *1472019984.958831 time.ctime(*)Wed Aug 24 14:26:24 2016 复制代码 1 %a 本地locale简化星期名称 2 %A 本地完整星期名称 3 %b 本地简化月份名称 4 %B 本地完整月份名称 5 %c 本地相应的日期和时间表示 6 %d 一个月中的第几天01 - 31 7 %H 一天中的第几个小时24小时制,00 - 23 8 %I 第几个小时12小时制,01 - 12 9 %j 一年中的第几天001 - 36610 %m 月份01 - 1211 %M 分钟数00 - 5912 %p 本地am或者pm的相应符13 %S 秒01 - 6114 %U 一年中的星期数。00 - 53星期天是一个星期的开场。第一个星期天之前的所有天数都放在第0周。15 %w 一个星期中的第几天0 - 6,0是星期天16 %W 和%U根本一样,不同的是%W以星期一为一个星期的开场。17 %* 本地相应日期18 %* 本地相应时间19 %y 去掉世纪的年份00 - 9920 %Y 完整的年份21 %Z 时区的名字如果不存在为空字符22 % %字符复制代码datetime当前时间:datetime.datetime.now()1、随机模块randomrandom.randint(1,3)则可以取出随机1-3random.randrange(1,3)随机从围所及random.choice()传递的参数是序列包括字符串列表等 random.choice(hello)l random.choice(hello)o random.choice(hello)e random.choice(我,爱,你)我 random.choice(我,爱,你)你 random.choice(我,爱,你)你 random.choice(我,爱,你)爱 random.sample随机从前面的序列取出两位 random.sample(hello,2)l, o random.sample(hello,2)h, l random.sample(hello,2)h, o random的洗牌功能: a=1,2,3,4,5,6,7,8,9 random.shuffle(a) a6, 3, 7, 4, 1, 8, 9, 2, 5 生成随机验证码的例子:复制代码 1 import string 2 import random 3 a = .join(random.sample(string.ascii_lowercase,4) 4 print(a) 5 b = .join(random.sample(string.ascii_lowercase+string.digits,5) 6 print(b) 7 8 c = .join(random.sample(string.ascii_uppercase+string.digits+string.ascii_lowercase,4) 9 print(c)10 d =.join(random.sample(string.ascii_letters+string.digits,4)11 print(d)复制代码运行结果如下:复制代码1 D:python35python.e*e D:/python培训/s14/day5/验证码2.py2 tbdy3 6te4b4 Z2UA5 v8He6 7 Process finished with e*it code 0复制代码5、os模块复制代码 1 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径 2 os.chdir(dirname) 改变当前脚本工作目录;相当于shell下cd 3 os.curdir 返回当前目录: (.) 4 os.pardir 获取当前目录的父目录字符串名:(.) 5 os.makedirs(dirname1/dirname2) 可生成多层递归目录 6 os.removedirs(dirname1) 假设目录为空,则删除,并递归到上一级目录,如假设也为空,则删除,依此类推 7 os.mkdir(dirname) 生成单级目录;相当于shell中mkdir dirname 8 os.rmdir(dirname) 删除单级空目录,假设目录不为空则无法删除,报错;相当于shell中rmdir dirname 9 os.listdir(dirname) 列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印10 os.remove() 删除一个文件11 os.rename(oldname,newname) 重命名文件/目录12 os.stat(path/filename) 获取文件/目录信息13 os.sep 输出操作系统特定的路径分隔符,win下为,Linu*下为/14 os.linesep 输出当前平台使用的行终止符,win下为tn,Linu*下为n15 os.pathsep 输出用于分割文件路径的字符串16 os.name 输出字符串指示当前使用平台。win-nt; Linu*-posi*17 os.system(bash mand) 运行shell命令,直接显示18 os.environ 获取系统环境变量19 os.path.abspath(path) 返回path规化的绝对路径20 os.path.split(path) 将path分割成目录和文件名二元组返回21 os.path.dirname(path) 返回path的目录。其实就是os.path.split(path)的第一个元素22 os.path.basename(path) 返回path最后的文件名。如何path以或结尾,则就会返回空值。即os.path.split(path)的第二个元素23 os.path.e*ists(path) 如果path存在,返回True;如果path不存在,返回False24 os.path.isabs(path) 如果path是绝对路径,返回True25 os.path.isfile(path) 如果path是一个存在的文件,返回True。否则返回False26 os.path.isdir(path) 如果path是一个存在的目录,则返回True。否则返回False27 os.path.join(path1, path2, .) 将多个路径组合后返回,第一个绝对路径之前的参数将被忽略28 os.path.getatime(path) 返回path所指向的文件或者目录的最后存取时间29 os.path.getmtime(path) 返回path所指向的文件或者目录的最后修改时间复制代码6、 sys模块复制代码1 sys.argv 命令行参数List,第一个元素是程序本身路径2 sys.e*it(n) 退出程序,正常退出时e*it(0)3 sys.version 获取Python解释程序的版本信息4 sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值5 sys.platform 返回操作系统平台名称6 sys.stdout.write(please:)复制代码7、shutil模块复制代码1 import shutil2 3 a = open(a.t*t,r,encoding=utf-8)4 b = open(b.t*t,w,encoding=utf-8)5 6 shutil.copyfileobj(a,b)复制代码运行够会复制一个文件b,将a文件中的容复制到b文件中shutil.copyfile(b.t*t,c.t*t)直接复制b.t*t到c.t*tshutil.copymode(src,dst) 仅拷贝权限。容,组,用户均不变shutil.copystat(src,dst)拷贝状态的信息shutil.copytree(src,dst,symlinks=false,ignore=none) 递归拷贝文件shutil.rmtree(path,ignore_errors,onerror)shutil.move(sr,dst)递归移动文件8、用于序列化的两个模块json&picklejson,用于字符串和 python数据类型间进展转换pickle,用于python特有的类型和 python的数据类型间进展转换Json模块提供了四个功能:dumps、dump、loads、loadpickle模块提供了四个功能:dumps、dump、loads、load9、关于shelve模块代码例子:复制代码 1 #AUTHOR:FAN 2 import shelve 3 import datetime 4 5 d = shelve.open(shelve_test) 6 7 info = name:dean,job:it,age:23 8 9 dname=infoname10 djob=infojob11 ddate=datetime.datetime.now()12 d.close()复制代码运行结果,会生成如下三个文件取出上述存的数据的代码如下:1 d = shelve.open(shelve_test)2 print(d.get(name)3 print(d.get(job)4 print(d.get(date)运行结果如下:复制代码1 D:python35python.e*e D:/python培训/s14/day5/shelve模块/shelve_test.py2 dean3 it4 2016-08-24 16:04:13.3254825 6 Process finished with e*it code 0复制代码10、正则re模块复制代码 1 . 默认匹配除n之外的任意一个字符,假设指定flag DOTALL,则匹配任意字符,包括换行 2 匹配字符开头,假设指定flags MULTILINE,这种也可以匹配上(ra,nabcneee,flags=re.MULTILINE) 3 $ 匹配字符结尾,或e.search(foo$,bfoonsdfsf,flags=re.MULTILINE).group()也可以 4 * 匹配*号前的字符0次或屡次,re.findall(ab*,cabb3abcbbac) 结果为abb, ab, a 5 + 匹配前一个字符1次或屡次,re.findall(ab+,ab+cd+abb+bba) 结果ab, abb 6 匹配前一个字符1次或0次 7 m 匹配前一个字符m次 8 n,m 匹配前一个字符n到m次,re.findall(ab1,3,abb abc abbcbbb) 结果abb, ab, abb 9 | 匹配|左或|右的字符,re.search(abc|ABC,ABCBabcCD).group() 结果ABC10 (.) 分组匹配,re.search(abc)2a(123|456)c, abcabca456c).group() 结果 abcabca456c11 12 13 A 只从字符开头匹配,re.search(Aabc,ale*abc) 是匹配不到的14 Z 匹配字符结尾,同$15 d 匹配数字0-916 D 匹配非数字17 w 匹配A-Za-z0-918 W 匹配非A-Za-z0-919 s 匹配空白字符、t、n、r , re.search(s+,abtc1n3).group() 结果 t20 S 匹配非空白字符复制代码r代表取消引号里面特殊字符的意义最常用的匹配语法:re.match从头开场匹配re.search匹配包含re.findall把所有匹配到的字符放到以列表中的元素返回re.splitall以匹配到的字符当做列表分隔符re.sub匹配字符并替换下面是关于正则的例子帮助理解:复制代码 1 re.match(zhao,zhaofan123) 2 3 re.match(ww,zhaofan123) 4 5 从这里也可以看出,如果有返回则表示匹配到了,否则则是没有匹配到 6 res = re.match(zhao,zhaofan123) 7 res 8 9 res.group() #如果想要查看匹配的容.group() 10 zhao 11 12 匹配zhao后面以及数字 13 res = re.match(zhaod,zhao2323fan123) 14 res.group() 15 zhao2 16 匹配多个数字 17 res = re.match(zhaod+,zhao2323fan123) 18 res.group() 19 zhao2323 20 21 22 查找特定字符 23 re.search(f.+n,zhao2323fan123) 24 25 26 re.search(f.+n,zhao2323fan123n) 27 28 29 30 re.search(fa-z+n,zhao2323fan123n) 31 32 33 $是匹配到字符串的最后 34 re.search(#.+#,1234#hello#) 35 36 37 re.search(aa,zhaaaofan) 38 39 re.search(aaa,zhaaaofan) 40 41 42 re.search(aaa,zhaaofan) 43 44 45 46 47 re.search(aaa,zhaaofaaan) 48 49 re.search(aaa,zhaofaaan) 50 51 re.search(aaa,zhaaofaaan) 52 53 从上面可以很好的理解?是匹配前一个字符0次或者1次 54 通俗的说就是aa后面有1个或者没有a都可以匹配到 55 re.search(0-93,aaa*234sdfaass22s) 56 57 58 匹配数字3次 59 re.search(0-93,aaa*234sdfaass22s) 60 61 62 匹配数字1次到3次 63 re.search(0-91,3,aaa23sdfsdf2323ss) 64 65 66 找到所有的数字 67 re.findall(0-91,3,sss23sdf2223ss11) 68 23, 222, 3, 11 69 70 71 re.search(abc|ABC,ABCabCD).group() 72 ABC 73 re.findall(abc|ABC,ABCabcCD) 74 ABC, abc 75 76 re.search(abc2,zhaofanabccc) 77 78 79 re.search(abc)2,zhaofanabcabc) 80 81 高级用法: 82 re.search(P0-9+),abc12345daf#s22) 83 84 re.search(P0-9+),abc12345daf#s22).group() 85 12345 86 re.search(P0-9+),abc12345daf#s22).groupdict() 87 id: 12345 88 89 90 91 split的用法: 92 re.split(0-9+,acb23sdf2d22ss) 93 acb, sdf, d, ss 94 95 sub替换的用法 96 re.sub(0-9+,#,234ssdfsdf23sdf22ss3s) 97 #ssdfsdf#sdf#ss#s 98 99 100 re.sub(0-9+,#,234ssdfsdf23sdf22ss3s,count=2)101 #ssdfsdf#sdf22ss3s102 .
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 管理文书 > 施工组织


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!