• 第十七天笔记


    一、模块的循环导入问题

    解决方案一:把循环导入的语句放到名字定义的后面

    例如:

    M1.py          M2.py         

    print(‘正在导入m1’)   print('正在导入m2')    

    x=‘m1’          y='m2'         

    from m2 import y      from m1 import x      

     解决方案二:将循环导入语句放到函数内

    m1.py

    print('正在导入'm1)'

    def f1():   from m2 import y,f2

      print('m1.f1---->y: ' ,y)

      f2() x='m1'

    二、区分python文件的俩种用途

    当文件被执行时__name__=='__main__' 当文件被导入时__name__=='模块名'

    三、模块的搜索路径1

    模块搜索路径的优先级

    1. 内存中已经加载过的

    2. 内置模块

    3. sys.path #  第一个值是当前执行文件所在的文件夹

    方案一:

    import sys

    sys.path.append(r'文件路径')

    print(sys,path)

    方案二:

    from 文件夹名字 import 要取的模块

    环境变量是以当前执行文件为准的

    强调:所有被导入的模块参照环境变量sys.path都是以执行文件为准的

    四、绝对导入和相对导入

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

    优点: 执行文件与被导入的模块中都可以使用 

    缺点: 所有导入都是以sys.path为起始点,导入麻烦

    相对导入: 参照当前所在文件的文件夹为起始开始查找,称之为相对导入 #        符号: .代表当前所在文件的文件加,..代表上一级文件夹,...代表上一级的上一级文件夹

    优点: 导入更加简单

    缺点: 只能在导入包中的模块时才能使用,不能在执行文件中用

  • 相关阅读:
    从无到有制作Deb包的一个实例
    Redis内存存储结构分析
    岳麓实践论
    金砖四国(巴西、俄罗斯、印度和中国)
    用LLVM开发新语言
    QQ云输入法
    http://baike.baidu.com/view/1926473.htm
    21世纪商业评论
    update ubuntu to 11.10
    gnu make 中文手册教程pdf
  • 原文地址:https://www.cnblogs.com/zhouhao123/p/9456339.html
Copyright © 2020-2023  润新知