模块(一)

一、模块

  1.模块:一系列功能的结合体

  2.三种来源:

    (1)内置的标准模块,执行help查看所有python自带模块列表

    (2)第三方开源模块,可通过pip install 模块名,联网安装

    (3)自定义模块

  3.四种表现形式:

    (1)使用python编写的py文件也可以称之为模块:一个py文件也可以称之为模块

    (2)已被编译为共享库或DLL的C或C++扩展(了解)

    (3)把一系列模块组织到一起的文件夹(文件夹下有一个__init__.py文件,该文件夹称之为包)包:一系列py文件的结合体

    (4)使用C编写并连接到python解释器的内置模块

  4.为什么要用模块?

    (1)用别人写好的模块(内置的,第三方的):典型的拿来主义,极大地提高了开发效率

    (2)使用自己写的模块(自定义的):当程序比较庞大的时候,你的项目不可能只在一个py中,那么当多个文件中都需要使用相同的方法的时候 可以将该公共的方法写到一个py文件中,其他的文件以模块的形式导过去直接调用即可

  5.使用方法:

import module

from module import xx

from module.xx.xx import xx as rename  

from module.xx.xx import *

  注意:一定要区分哪个是执行文件,哪个是被导入文件

二、import...

  1.模块的导入:直接导入文件的名字,不需要带着后缀

  2.模块的函数调用:模块名.函数名()

  3.右键运行run.py文件首先会创建一个run.py的名称空间:

    首次导入模块(md1.py)

    (1)执行md.py文件

    (2)运行md.py文件中的代码将产生的名字与值存放到md.py名称空间中

    (3)在执行文件中产生一个指向名称空间的名字(md)

    注意:多次导入不会在执行模块文件,会沿用第一次导入的成果

  4.当几个模块有相同部分或属于一个模块时可以用下列方式:

import os,time,md

   当几个模块没有联系的情况下,应该分多次导入,如下:

import os
import time
import md

   当模块名字比较复杂的情况下,可以给该模式名取别名

  ps:异常有两大类:

    (1)语法结构错误:需要你当场修改,异常捕获没法完成

    (2)逻辑错误:异常捕获可以处理

三、from...import...

  1.导入什么就用什么,不导入的一律不能用

    会先创建run1.py的名称空间

    首次导入md1.py模块

      (1)运行md1.py

      (2)将产生的名字存放到md1.py名称空间中

      (3)直接拿到指向模块md1.py名称空间中某个值的名字

  2.被import导入的名字就相当于属于全局变量

from xx import read1
read1()
from xx import read2
read2()

  3.它的缺点;

    (1)访问模块中的名字不需要加模块名前缀

    (2)在访问模块中的名字可能会与当前执行文件中的名字冲突

  4.from...import *(不推荐)

    一次性将某模块中的名字全部加载过来

  5.__all__可以指定当所在py文件被当做模块导入的时候,限制导入者能够拿到的名字个数

四、循环导入

  1.循环导入问题:

    执行文件运行时,两个导入文件互相导入时,会导致一个导入文件中的导入代码下方的代码没有执行,而另一个导入文件却调用了,然后报错

    如果出现循环导入问题,那么一定是你的程序设计的不合理

    循环导入问题应该在程序设计阶段就应该避免

  2.解决循环导入问题的方式:

    (1)方式1:

      将循环导入的句式写在文件最下方()

    (2)方式2:

      函数内导入模块

  ps:__name__作用:

    当文件被当做执行文件执行的时候__name__打印的结果是__main__

    当文件被当做模块导入的时候__name__打印的结果是模块名(没有后缀)

    快捷写法:main直接tab键

def index1():
    print('index1')

def index2():
    print('index2')

print(__name__)

if __name__ == '__main__':  # 快捷写法 main直接tab键即可
    index1()
    index2()

  模块的查找顺序:

    (1)先从内存中找

import time
import md
time.sleep(20)
md.f1()

    (2)内置中找

import time
print(time.name)

    (3)sys.path中找(环境变量):

        一定要分清谁是执行文件,谁是被导入文件

        是一个大列表,里面放了一对文件路径,第一个路径永远是执行文件所在的文件夹

import sys
sys.path.append(r'D:\Python项目\day14\dir1')
print(sys.path)

五、相对导入

  1. .代表的当前路径  ..代表的上一级路径  ...代表的是上上一级路径

    注意:相对导入不能再执行文件中使用

      相对导入只能在被导入的模块中使用,使用相对导入就不需要考虑

      执行文件到底是谁,只需要知道模块与模块之间路径关系  

六、绝对导入

  1.绝对导入必须依据执行文件所在的文件夹路径为准

  2.绝对导入无论在执行文件中还是被导入文件都适用

七、软件开发目录规范

  1.项目的启动文件通常放在两个地方

    (1)bin文件夹下

    (2)直接在项目根目录

  2.ATM+购物车:

    项目名

    bin文件夹:start.py项目启动文件

    conf文件夹:settings.py项目配置文件

    core文件夹:src.py项目核心逻辑

    db文件夹:数据库相关文件

    lib文件夹:common.py项目所用到的公共的功能

    log文件夹:log.log项目的日志文件

    readme.txt文本文件:项目简介

  3.start.py内容

import sys
import os

BASE_DIR = os.path.dirname(os.path.dirname(__file__))
sys.path.append(BASE_DIR)
"""
pycharm会自动将你新建的最顶层的目录自动添加到环境变量中
上面这两句话 不是针对你的 是针对下载你这个软件的用户
"""
from core import src

if __name__ == '__main__':
    src.run()


# 1.将core文件路径添加到system path中   ...太low
# 2.将ATM文件夹添加到system path中
posted @ 2019-07-16 17:32  静心学  阅读(131)  评论(0)    收藏  举报