day21 01包的初识

包:把解决一类问题的模块放在同一个文件夹里面-----包(一个包里面通常会含有_init_.py文件(python2里面必须有),但是后面的就没有要求一定要有了)

同样导入的时候有import和 from  import 两种

注意:凡是导入是带点的,点的左边必须是一个包模块,对于from import类型的来说,import后面不能带有点,(from glance import policy.api是错误会报错)

在pcharm的project里面建立了一个glance包,而glance包里面又有api,cmd,db包还有一个_init_.py文件,再在api包里面又有一个policy.py和_versions_.py文件,

cmd里面有一个_init_.py和manage.py文件,而db包里面有一个models.py文件,要想生成这些文件,可执行以下代码:

import os
os.makedirs('glance/api')
os.makedirs('glance/cmd')
os.makedirs('glance/db') #创建三个目录
l=[] #创建一个列表,是为了下面将七个文件统一关闭
l.append(open('glance/_init_.py','w'))
l.append(open('glance/api/_init_.py','w'))
l.append(open('glance/api/policy.py','w'))
l.append(open('glance/api/versions.py','w'))
l.append(open('glance/cmd/_init_.py','w'))
l.append(open('glance/cmd/manage.py','w'))
l.append(open('glance/db/models.py','w')) #打开七个文件,同时生成文件句柄,把这七个文件句柄放到列表中
map(lambda f:f.close(),l) #拿到列表里面每一个文件句柄,并进行关闭

各个生成的文件里面的内容:

policy.py

def get():
print('from policy.py')

versions.py

def create_resource(conf):
print('from versions.py: ',conf)

manage.py

def main():
print('from manage.py')

models.py

def register_models(endine):
print('from models.py: ',engine)

生成一个glance包后,我们就可以执行导入的操作了:

(1)直接import+包点包点.....点方法,然后 print(包点包点.....点方法点get())就可以看到是否导入了

import glance.api.policy as policy
policy.get()

运行结果:

from policy.py

(2)from 包点包点......点包 import  方法(这种方法需要注意import后面不能带点)

from glance.api import policy
policy.get()

运行结果:

from policy.py

如果此时在project下面还有glance外面再建一个dir文件夹,此时要import glance就找不到了,因为:

导入的时候是根据以下路径导入的,当将glance放到dir下面的时候,只找到了前面两个而且都是'C:\\Users\\sku1-1\\PycharmProjects\\untitled',后面就与它无关了,

而glance在dir里面,dir在它的里面,后面没有说明就找不到了。

import sys
print(sys.path)

运行结果:

['C:\\Users\\sku1-1\\PycharmProjects\\untitled', 'C:\\Users\\sku1-1\\PycharmProjects\\untitled', 'C:\\Users\\sku1-1\\PycharmProjects\\untitled\\venv\\Scripts\\python35.zip', 'C:\\Users\\sku1-1\\AppData\\Local\\Programs\\Python\\Python35\\DLLs', 'C:\\Users\\sku1-1\\AppData\\Local\\Programs\\Python\\Python35\\lib', 'C:\\Users\\sku1-1\\AppData\\Local\\Programs\\Python\\Python35', 'C:\\Users\\sku1-1\\PycharmProjects\\untitled\\venv', 'C:\\Users\\sku1-1\\PycharmProjects\\untitled\\venv\\lib\\site-packages', 'C:\\Users\\sku1-1\\PycharmProjects\\untitled\\venv\\lib\\site-packages\\setuptools-39.1.0-py3.5.egg', 'C:\\Users\\sku1-1\\PycharmProjects\\untitled\\venv\\lib\\site-packages\\pip-10.0.1-py3.5.egg', 'C:\\Program Files\\JetBrains\\PyCharm 2018.2.2\\helpers\\pycharm_matplotlib_backend']

要想找到glance,只能通过:

from dir.glance.api import policy
policy.get()

或者先添加一个路径给它:

sys.path.insert(0,'C:\\Users\\sku1-1\\PycharmProjects\\untitled\\dir')#在第一个路径插入,这里多了一个dir
from glance.api import policy
policy.get()

运行结果:

from policy.py

如果按照以下代码执行导入:

import glance
glance.api.policy.get()#找不着

是会报错的,运行结果:

Traceback (most recent call last):
File "<encoding error>", line 23, in <module>
AttributeError: module 'glance' has no attribute 'api'

为什么呢?

平时我们导入一个模块,就会执行这个模块,但是导入一个包,它不会执行里面的方法,而是默认执行它里面的_init_.py文件,可以在_init_.py文件里面放一些内容,

并执行 import glance就可以验证了

由于每次导入一个包都会执行它的init文件,所以可以在_init_.py里面进行操作,所以先在dir下的_init_.py文件里面导入:

from glance import api
from glance import cmd
from glance import db

而此时也还是导入了一个 api,cmd,db包,还是不会执行api里面的policy方法,同样跟上面一样,继续在glance包里面的_init_.py文件导入policy:

from glance.api import policy

此时我们就可以执行以下代码,而不会报错了

import glance
glance.api.policy.get()

运行结果:

from policy.py

day21 01 包的初识的更多相关文章

  1. day21 02 包的进阶

    day21 02 包的进阶 1._init_.py文件的操作---导入包 根据day21 01 包的初识,建立的glance包,直接import glance后通过“包点包..点方法”是不能执行所要的 ...

  2. day 21 01 序列化模块和模块的导入的复习以及包的初识

    day 21 01 序列化和模块的导入的复习以及包的初识 1.序列化模块 什么是序列化模块:数据类型转化成字符串的过程就是序列卷 为什么要使用序列化模块:为了方便存储和网络传输 三种序列化模块: (1 ...

  3. Python函数01/函数的初识/函数的定义/函数调用/函数的返回值/函数的参数

    Python函数01/函数的初识/函数的定义/函数调用/函数的返回值/函数的参数 内容大纲 1.函数的初识 2.函数的定义 3.函数的调用 4.函数的返回值 5.函数的参数 1.函数初识 # def ...

  4. 01 Mysql数据库初识

    一.数据库概述 1.什么是数据库? 什么是数据库呢? 先来看看百度怎么说的 数据库,简而言之可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据运行新增.截取.更新.删除等操作. 所谓“ ...

  5. Fiddler-001-抓包工具初识

    Fiddler 是一个非常简单的网络调试器,也是目前最常用的http抓包工具之一 .通过 Fiddler,我们能够能够记录客户端和服务器之间的所有 HTTP请求,即记录并检查所有你的电脑和互联网之间的 ...

  6. 包的初识和进阶&异常处理

    包 包是一种通过使用‘.模块名’来组织python模块名称空间的方式. 1. 无论是import形式还是from...import形式,凡是在导入语句中(而不是在使用时)遇到带点的,都要第一时间提高警 ...

  7. hdu1864(01包)

    最大报销额 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  8. python模块, 包的初识

    Python 模块(Module), 是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和Python语句. 模块让你能够有逻辑地组织你的 Python 代码段. 把相关的代 ...

  9. DP的初级问题——01包、最长公共子序列、完全背包、01包value、多重部分和、最长上升子序列、划分数问题、多重集组合数

    当初学者最开始学习 dp 的时候往往接触的是一大堆的 背包 dp 问题, 那么我们在这里就不妨讨论一下常见的几种背包的 dp 问题: 初级的时候背包 dp 就完全相当于BFS DFS 进行搜索之后的记 ...

随机推荐

  1. flask-migrate 数据迁移

    作用:做数据库迁移依赖:flask-script flask-sqlalchemy 使用 项目结构 manage.py(其它文件内容与flask-sqlalchemy中一样) from s8day13 ...

  2. 短链接及关键字过滤ac自动机设计思路

    =============:短链接设计思路:核心:将长字符转为短字符串并建立映射关系,存储redis中.1.使用crc32转换为Long 2.hashids将long encode为最短字符串.作为短 ...

  3. Objective-C 继承与类

    创建: 2018/01/20 完成: 2018/01/21 更新: 2018/01/22 标题前增加 [Objective-C]  继承的概念  父类与子类 ●继承: 继承其他类 ●父类: 被继承的类 ...

  4. bzoj 1026: [SCOI2009]windy数【数位dp】

    忘记limit不能记WA了一发-- 典型数位dp,变成work(r)-work(l-1),然后dfs的时候记录w当前位置,la上一个数选的什么,lm当前位是否有上限,ok当前位是否可以不考虑差大于等于 ...

  5. bzoj 1426: 收集邮票【期望dp】

    我太菜了,看的hzwer的blog才懂 大概是设f[i]表示已经拥有了i张邮票后期望还要买的邮票数,这个转移比较简单是f[i]=f[i]*(i/n)+f[i+1]*((n-i)/n)+1 然后设g[i ...

  6. SP2916 GSS5 - Can you answer these queries V

    给定一个序列.查询左端点在$[x_1, y_1]$之间,且右端点在$[x_2, y_2]$之间的最大子段和,数据保证$x_1\leq x_2,y_1\leq y_2$,但是不保证端点所在的区间不重合 ...

  7. 洛谷 P1462 通往奥格瑞玛的道路(spfa+二分搜索)(4boy)

    原题:http://www.luogu.org/problem/show?pid=1462#sub 4boy: 大意:给出n个城市,有m条路,每经过一个城市都要交钱,每经过一条道路都要扣HP,有HP上 ...

  8. iOS静态库.Framework制作

    首先要解释一下什么是库,库(Library)其实就是一段编译好的二进制代码,加上头文件就可以供别人使用,一般会有两种情况要用到库: 某些代码需要给别人使用,但是我们不希望别人看到源码,就需要以库的形式 ...

  9. 6.12---前提两个对象的成员必须一致,才能将有数据的对象将数据传给反射获取的对象conver(有数据对象,目标对象)

    //// Source code recreated from a .class file by IntelliJ IDEA// (powered by Fernflower decompiler)/ ...

  10. java实现麦克风自动录音

    最近在研究语音识别,使用百度的sdk.发现只有识别的部分,而我需要保存音频文件,并且实现当有声音传入时自动生成音频文件. 先上代码: public class EngineeCore { String ...