python学习 day5

模块

1.定义:

     模块本质上就是以.py结尾的python文件,用来从逻辑上组织python代码(变量,函数,类),从而实现其功能。

     包本质上是一个目录(必须包含一个_init_.py文件),用来从逻辑上组织模块。

2.导入方法:

import module_name
import module_name1,module_name2
from module_name import *
from module_name import name1,name2
from module_name import name as name2

3.import本质:

      导入模块的本质就是把python文件解释一遍。

      导入包的本质是执行该包下的_init_.py文件。

4.导入优化:

import module ------>module.name()
from module import name-------->name()

在多次使用name函数的情况下,后者可以省略重复的在module中寻找name函数的过程。

5.模块的分类:

     a.标准模块(内置模块)

     b.开源模块(第三方模块)

     c.自定义模块

一,标准模块

    1 time与datetime模块

      time模块:

      时间的表现形式 :(1)time.time()时间戳,从1970年至今的秒数。(2)格式化的时间字符串。(3)元组形式,九要素,年月日,时分秒,一周中的第几天,一年中的第几天,是否为夏令时。

      datetime模块:

获取当前时间 datetime.datetime.now()

时间加减:
datetime.datetime.now()+datetime.timedelta(3)    当前时间向后3天
datetime.datetime.now()+datetime.timedelta(-3)   当前时间向前3天
datetime.datetime.now()+datetime.timedelta(hours=-3)   当前时间向前3小时
datetime.datetime.now()+datetime.timedelta(minutes=3)  当前时间向后3分钟


       2  random模块

import random
#随机整数
print(random.randint(0,99))    #----->10

#随机选取0到100间的偶数
print(random.randrange(0,101,2))    #----->20

#随机浮点数
print(random.random())     #  默认0到1,----->0.8341288849661739
print(random.uniform(1,10))     #----->1.412662519468776

#随机字符
print(random.choice("abnckfhxhu"))   #----->h
#随机选取字符串
print(random.choice(["apple","pear","banana"]))  #  注意,要用列表形式表现----->apple

#多个字符串中选取随机数量的字符
print(random.sample("abcdefghijk",3))    #----->['h', 'j', 'g']

#洗牌
items=[1,2,3,4,5,6]
print(items)    #----->[1, 2, 3, 4, 5, 6]
random.shuffle(items)
print(items)    #   注意,如果直接print上一步,输出为None----->[6, 4, 3, 2, 5, 1]
#简易的4位验证码功能
import random
check_code=""
for i in range(4):
    current=random.randint(1,9)
    if current==i:
        a=chr(random.randint(65,90))     #chr()将数字转换为ASCII码中对应的对象
    else:
        a=current
    check_code+=str(a)
print(check_code)

    3 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    输出用于分割文件路径的字符串
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所指向的文件或者目录的最后修改时间

    4 shutil模块

        高级的 文件、文件夹、压缩包 处理模块(copy,压缩)

         参考http://www.cnblogs.com/wupeiqi/articles/4963027.html 

   

    5 json与pickle模块

       序列化与反序列化,load,loads,dump,dumps

    6 shelve模块

       比json、pickle更简便的备份

import shelve
import datetime

f=shelve.open("shelve_file")
name=["alex","alice","wang"]
info={"age":22,"sex":"female"}


# 备份
# f["name"]=name
# f["info"]=info
# f["datetime"]=datetime.datetime.now()


#读取
print(f.get("name"))

f.close()

  

    7 xml模块

        参考http://www.cnblogs.com/alex3714/articles/5161349.html

    8 正则表达 re模块(模糊匹配)

        常用正则表达匹配符号

'.'     默认匹配除\n之外的任意一个字符,若指定flag DOTALL,则匹配任意字符,包括换行

'^'     匹配字符开头,若指定flags MULTILINE,这种也可以匹配上(r"^a","\nabc\neee",flags=re.MULTILINE)

'$'     匹配字符结尾,或e.search("foo$","bfoo\nsdfsf",flags=re.MULTILINE).group()也可以

'*'     匹配*号前的字符0次或多次,re.findall("ab*","cabb3abcbbac")  结果为['abb', 'ab', 'a']

'+'     匹配前一个字符1次或多次,re.findall("ab+","ab+cd+abb+bba") 结果['ab', 'abb']

'?'     匹配前一个字符1次或0次

'{m}'   匹配前一个字符m次

'{n,m}' 匹配前一个字符n到m次,re.findall("ab{1,3}","abb abc abbcbbb") 结果'abb', 'ab', 'abb']

'|'     匹配|左或|右的字符,re.search("abc|ABC","ABCBabcCD").group() 结果'ABC'

'(...)' 分组匹配,re.search("(abc){2}a(123|456)c", "abcabca456c").group() 结果 abcabca456c

 

 

'\A'    只从字符开头匹配,re.search("\Aabc","alexabc") 是匹配不到的

'\Z'    匹配字符结尾,同$

'\d'    匹配数字0-9

'\D'    匹配非数字

'\w'    匹配[A-Za-z0-9]

'\W'    匹配非[A-Za-z0-9]

's'     匹配空白字符、\t、\n、\r , re.search("\s+","ab\tc1\n3").group() 结果 '\t'

 

'(?P<name>...)' 分组匹配 re.search("(?P<province>[0-9]{4})(?P<city>[0-9]{2})(?P<birthday>[0-9]{4})","371481199306143242").groupdict("city") 结果{'province': '3714', 'city': '81', 'birthday': '1993'} 


  

        常用正则表达匹配语法

re.match 从头开始匹配

re.search 匹配包含

re.findall 把所有匹配到的字符放到以列表中的元素返回

re.split    以匹配到的字符当做列表分隔符

re.sub      匹配字符并替换

 

     

猜你喜欢

转载自www.cnblogs.com/2625377029wwj/p/8972967.html