• 包的使用


    1. 为何要使用包?

      包的本质就是一个文件夹,那么文件夹唯一的功能就是将文件组织起来,随着功能越写越多,我们无法将所有功能都放到一个文件中,于是我们使用模块去组织功能,而随着模块越来越多,我们就需要用文件夹将模块文件组织起来,以此来提高程序的结构性和可维护性

    2. 注意事项

      1. 关于包相关的导入语句也分为import和from ... import ...两种.但是无论哪种,无论在什么位置,在导入时都必须遵循一个原则:凡是在导入时带点的,点的左边都必须是一个包,否则非法.可以带有一连串的点,如item.subitem.subsubitem,但都必须遵循这个原则.但对于导入后,在使用时就没有这种限制了,点的左边可以是包,模块,函数,类(它们都可以用点的方式调用自己的属性).
      2. import导入文件时,产生名称空间中的名字来源于文件,import 包,产生的名称空间的名字同样来源于文件即包下的__init__.py,导入包本质就是在导入该文件
      3. 包A和包B下有同名模块也不会冲突,如A.a与B.a来自俩个命名空间
    3. 包的使用

      # 示例文件
      bolg
      |____ ceshi
      |    |__ceshi2
      |    |  |__ __init__.py
      |    |  |__ m3.py
      |    |	
      |    |__ __init__.py
      |    |__ m1.py
      |    |__ m2.py
      |
      |____ run.py
      ----------------------------------------------------
      # 文件内容
      # m1.py
      def f1():
      	print('in ceshi m1 f1')
      ----------------------------------------------------
      # m2.py
      def f2():
      	print('in ceshi m2 f2')
      ----------------------------------------------------
      # m3.py
      def f3():
          print('in ceshi2 m3 f3')
      def f4():
          f1()
      
      # 第一类: 执行文件通过import导入包以及包内的功能
      # 创建一个包: Python Package,会自行创建一个 __init__.py 文件
      # 回忆: 创建一个模块发生的三件事:
      #     1.将该模块加载到内存
      #     2.创建一个以模块名命名的名称空间
      #     3.通过模块名.的方式引用模块内的所有的名字
      ----------------------------------------------------
      # 创建一个包,也会发生三件事:
      #     1.将该包内的__init__.py文件加载到内存
      #     2.创建一个以包名命名的名称空间
      #     3.通过包.的方式引用__init__的所有的名字
      ----------------------------------------------------
      # 我想要引用ceshi包的m1文件的f1
      # 错误示例1:
      #     1.ceshi的init里面写了 import f1
      #     2.ceshi.f1()
      #     报错: ModuleNotFoundError: No module named 'f1'
      #     分析报错原因: 模块找不到就是内存,内置,sys.path三个地方找不到
      #     f1不在内存,不在内置,不在sys.path,sys.path会自动加载执行文件(包的使用)的当前工作目录
      
      # 解决方式:
      #     1.在执行文件写inport ceshi
      #     2. 在ceshi的__init__里面写 from ceshi import m1
      import ceshi
      ceshi.m1.f1()
      
      # 或 在在ceshi的__init__里面写 from ceshi.m1 import f1
      import ceshi
      ceshi.f1()
      -----------------------------------------------------
      # 如何在当前文件中,引用ceshi里的ceshi2包
      #   1.在执行文件写inport ceshi
      #   2. 在ceshi的__init__里面写 from ceshi import ceshi2
      -----------------------------------------------------
      # 如何在当前文件中,引用ceshi包的ceshi2包的m3文件的f3
      #     1.在执行文件写入 import ceshi
      #     2.在ceshi包的__init__写入from ceshi import ceshi2(这样ceshi2包的__init__所有名字都可以引用)
      #     3.在ceshi2包的__init__写入from ceshi.ceshi2 import m3
      #      或 from ceshi.ceshi2.m3 import f3
      #      或 from .m3 import f3  (一个.代表当前目录)
      ceshi.ceshi2.m3.f3()
      
      # 第二类: 执行文件通过from...import...导入包以及包内的功能
      # 需要注意的是from后import导入的模块,必须是明确的一个不能带点,否则会有语法错误,如:from a import b.c是错误语法
      
      from ceshi import m1
      m1.f1()
      
    4. 绝对导入和相对导入

      • 绝对导入:以bolg作为起始

      • 相对导入:用.或者..的方式最为起始(只能在一个包中使用,不能用于不同目录内)

      • 无论对ceshi模块有任何操作,对于使用者来说不应该改变,极少的改变对其的调用方式

      • 绝对导入:以执行文件的sys.path为起始点开始导入,称之为绝对导入

        • 优点: 执行文件与被导入的模块中都可以使用
        • 缺点: 所有导入都是以sys.path为起始点,导入麻烦
      • 相对导入:参照当前所在文件的文件夹为起始开始查找,称之为相对导入

        • 符号:.代表当前所在文件的文件加,..代表上一级文件夹,...代表上一级的上一级文件夹
        • 优点:导入更加简单
        • 缺点:只能在导入包中的模块时才能使用
        • 注意:相对导入只能用于包内部模块之间的相互导入,导入者与被导入者都必须存在于一个包内
  • 相关阅读:
    java中Map遍历的四种方式
    Java从网络读取图片并保存至本地
    spring整合问题分析之Write operations are not allowed in readonly mode (FlushMode.MANUAL): Turn your Session into FlushMode.COMMIT/AUTO or remove 'readOnly' marker from transaction definition.
    element 中table表格多选,翻页或者切换不同数据后保存之前选择的数据并返显选中的状态
    nvm的安装与使用(Mac 版)
    常用正则表达式
    uniapp开发微信小程序
    关于elementui select组件change事件只要数据变化就会触发的解决办法
    elementui的表单重置方法resetFields()的坑
    Element中vfor动态数据循环表单验证的处理
  • 原文地址:https://www.cnblogs.com/zyyhxbs/p/11116784.html
Copyright © 2020-2023  润新知