day21 02 包的进阶

2023-01-31 00:01:53 进阶 day21

day21 02 包的进阶

 

1._init_.py文件的操作---导入包

       根据day21 01 包的初识,建立的glance包,直接import glance后通过“包点包。。点方法”是不能执行所要的方法的,必须通过在一层一层里面的_init_.py或者其他类似的文件做相对应的导入操作,才可以运行以下代码而不会报错:

import glance
glance.api.policy.get()

 

2.绝对路径导入

将建立的glance包放入新建的dir文件夹中,然后执行代码:

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

看着这代码似乎合情合理,但是运行结果会报错,为什么呢?这和前面所说的路径问题有关:

       当你运行 from dir import glance的时候,通过sys.path可以知道,会把你当前运行所在的页面的路径保存到sys.path的第一个,比如你当前的界面的路径是'C:\\Users\\sku1-1\\PyCharmProjects\\untitled,但是在此目录下并没有找到glance这个包,以至于glance里面的init文件也不会执行,后面就会报错,而要想不会报错就需要通过确切的路径去执行:

 

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

 

这样确切的路径就称为绝对路径,绝对路径的

优点:比较直观,不管是在内部还是外部,导入就能使用

缺点:就是包不能挪动,一挪动就会出错

 

3.相对路径导入(一般在自己可以完全制作一个完整的包的时候再使用)

一个点:代表当前目录

两个点:代表上一层目录

在glance包下面的_init_.py文件夹中输入:

 

from . import api
from . import cmd
from . import db

 

就是从当前文件夹中导入api,cmd,db,同时在api,cmd包下的_init_.py文件输入:

from . import policy
from . import versions
from . import manage

然后在运行界面执行:

import glance
glance.api.policy.get()

就可以使用policy方法了

如果将glance放入dir文件中,执行:

from dir import glance
glance.cmd.manage.get()

同样可以使用cmd里面的方法,这种使用当前目录导入包的方法

优点:可以随意移动包,只要能找到包的位置,就可以使用包里面的方法

缺点:不能在包里使用这个模块了,比如包下面文件与文件之间的函数的相互调用,只能使用相对路径,使用了相对路径就不能在内部直接执行了

比如:在policy模块里面使用cmd模块的方法:

def get():
    print('from policy.py')
from dir import glance
glance.cmd.manage.main()

此时运行结果将会报错:只要使用了相对路径导入包,包里面所有使用相对路径去使用的都是会报错的,但是在包外面是可以随意使用的

 

4.from 包 import * 和_all_相对导入

在glance包里面的_init_.py文件添加内容:

from .api import *
from .cmd import *
from .db import *

在api,cmd,db里面的_init_.py文件分别写入:

_all_=['policy','versions']
_all_=['manage']
_all_=['models']

这样就可以把api,cmd,db里面所有的方法都执行了,后面要调用policy,直接

import glance
policy.get()

就可以调用policy方法了,但是把api,cmd,db隔离开,相当于都没有它们名字本身什么事了,这种方法其实也是使用相对路径,也就存在相对路径的优缺点

对于初学者来说:要一定会使用绝对导入,而了解相对导入

 

5.使用python编程软件开发的一些规范

(1)bin文件:程序入口,文件里面有个start.py,一般里面放的内容基本是固定

(2)core文件:软件核心代码

   假如这两个文件里面含有:

bin文件里面
    init_.py
    start.py
core文件里面
    _init_.py
    core.py文件里面
          def main:
print('main') login.py文件里面:
def login:
print('login')

此时要想在core.py文件里面调用login(),如何实现呢?

首先在bin文件里面的start.py里面写入:

import os
import sys
sys.path.append(os.path.dirname(os.getcwd()))
#os.getcwd()获取次页面所在的目录,即bin的目录
# os.path.dirname(os.getcwd())#获取bin所在的目录,即当前页面所在的上层目录,而bin所在的目录还包含了core文件
#sys.path.append(os.path.dirname(os.getcwd()))将获取到的上层目录添加到os.path中
# 这样当在此页面开始执行的时候bin和core文件里面的都可以找得到,所以可以直接导入bin和core里面的方法调用函数
from core import core#从core里面导入core模块,并执行
if _name_=='_main_':#在此页面执行的时候,就执行以下代码
    core.main()#调用core里面的main函数

由于添加了上层目录的问题,可以直接在core.py里面导入login模块,然后直接调用login模块里面的login函数:

from core import login#从core里面导入login模块
def main():
    print('main')
    login.login()#已经导入login模块了,可以直接调用函数了

运行start.py页面,结果:

main
login

(3)conf文件:配置文件,放置一些任何人都可以看得懂的东西:一般给运维人员看的,一般他们不懂代码,但是他们可以通过调参数,改变代码

(4)db文件:数据库,比如登入认证的的数据

(5)lib文件:自己写的通用模块或包,完整模块,不需要安装

(6)log文件:日志,记录一些执行结果,待后面去查询

   现在只是大概有一个思路,好多都还不会,后面会讲到

 

相关文章