包:

 函数过多,可以分模块文件去管理函数,模块文件过多,将模块文件分类放在一个个的文件夹中,这个文件夹就叫做包,组织结构更加清晰,合理!

  模式就是被别人使用,包既然是一些模块的集合,也是被调用。

  文件:

    1、 被别人使用

    2、当做脚本自己使用

    执行文件运行时,会将执行文件的当前目录记载到sys.path的列表中

包也是模块,他是模块的集合体,所以引用包也会反生三件事情:

1、创建一个以包名命名的名称空间

2、执行包中的__init__文件,将__init__里面的代码块,加载到以包名命名的名称空间中

3、调用包内的名字必须通过包名. 的方式

 

 

# 想要在此文件引用 bbb包的m3模块 怎么做?
# 第一步 在此文件 import aaa
# 第二步:在aaa 的 __init__ 添加 from aaa import bbb
# 第三步:在bbb 的 __init__ 添加 from aaa.bbb import m3
# 完成以上三步,那么我在此执行文件就可以引用bbb包的m3模块里面的名字。
# aaa.bbb.m3.func3()

# 上面的需求满可以这么做:
# from aaa.bbb import func3
# m3.func3()

总结:

1、from a.b import c      . 的左边一定十个包,import后面一定是一个具体的名字

2、包里面的__init__ 如果想要引用模块,必须是 from.... import ....

3、from  a.b.c.d import e.f.g  错误,import右边不能有点(.)

4、form  a.b.c.d import e

 

相对导入和绝对导入:

# 绝对导入
from NB1.m1 import f1,f2
# 这样导入是为了让 00代码草稿 访问
# 如果只是在NB1的__init__使用,直接from m1 import f1, f2 即可
from NB1.m2 import f3,f4
from NB1.m3 import f5,f6

# 相对导入
from .m1 import f1,f2
from .m2 import f3,f4
from .m3 import f5,f6

总结:

绝对导入: 以执行文件的sys.path为起始点开始导入,称之为绝对导入
优点: 执行文件与被导入的模块中都可以使用
缺点: 所有导入都是以sys.path为起始点,导入麻烦

相对导入: 参照当前所在文件的文件夹为起始开始查找,称之为相对导入
符号: .代表当前所在文件的文件加,..代表上一级文件夹,...代表上一级的上一级文件夹
优点: 导入更加简单
缺点: 只能在导入包中的模块时才能使用

 import random:

# print(random.random())  #  大于0且小于1之间的小数
# print(random.uniform(1,3))  # #大于1小于3的小数
# print(random.randint(1,5))  # 大于等于1且小于等于5之间的整数
# print(random.randrange(1,10,2))  # 10以内的奇数
# print(random.choice(['alex','wusir','日天'])) # 多选一
# print(random.sample(['alex','wusir','日天','太白'],2)) # 多选多
# 打乱列表顺序
l1 = [1,2,3,4,'alex']
random.shuffle(l1)
print(l1)

生成随机验证码

def cond():
    cond1 = ''
    for i in range(4):
        l1 = random.randrange(10)
        l2 = chr(random.randrange(97,122)) # ASCII码 a~z 对应 97~122
        l3 = chr(random.randrange(65,90))  # 大写 A~Z
        single = random.choice([l1,l2,l3])
        cond1 += str(single)
    print(cond1)
cond()

 

import shutil

shutil.copyfileobj(fsrc, fdst[, length])
将文件内容拷贝到另一个文件中

import shutil
shutil.copyfileobj(open('file1','r'),open('file2','w'))

shutil.copyfile(src, dst)
拷贝文件

shutil.copyfile('f1.log', 'f2.log') #目标文件无需存在

shutil.copymode(src, dst)
仅拷贝权限。内容、组、用户均不变

shutil.copymode('f1.log', 'f2.log') #目标文件必须存在

shutil.copystat(src, dst)
仅拷贝状态的信息,包括:mode bits, atime, mtime, flags

shutil.copystat('f1.log', 'f2.log') #目标文件必须存在

shutil.copy(src, dst)
拷贝文件和权限

shutil.copy('f1.log', 'f2.log')

shutil.copy2(src, dst)
拷贝文件和状态信息

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 对压缩包的处理是调用 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压缩解压缩

 

posted on 2019-01-10 21:19  拾玥大熊  阅读(115)  评论(0编辑  收藏  举报