python3 import注意点
# impot导入模块在使用时必须加前缀"模块."
# 优点:肯定不会与当前名称空间中的名字冲突
# 缺点:加前缀显得麻烦
# from ... import ...导入也发生了三件事
# 1、产一个模块的名称空间
# 2、运行foo.py将运行过程中产生的名字都丢到模块的名称空间去
# 3、在当前名称空间拿到一个名字,该名字与模块名称空间中的某一个内存地址
# from foo import x # x=模块foo中值0的内存地址
# from foo import get
# from foo import change
# print(x)
# print(get)
# print(change)
# x=333333333
# print(x)
# get()
# change()
# get()
# print(x)
# from foo import x # x=新地址
# print(x)
# from...impot...导入模块在使用时不用加前缀
# 优点:代码更精简
# 缺点:容易与当前名称空间混淆
# from foo import x # x=模块foo中值1的内存地址
# x=1111
# 一行导入多个名字(不推荐)
# from foo import x,get,change
# *:导入模块中的所有名字
# name='egon'
# from foo import *
# print(name)
from socket import *
# 了解:__all__
# from foo import *
# print(x)
# print(get)
# print(change)
# 起别名
from foo import get as g
print(g)
模块的搜索路径优先级
# 无论是import还是from...import在导入模块时都涉及到查找问题
# 优先级:
# 1、内存(内置模块)
# 2、硬盘:按照sys.path中存放的文件的顺序依次查找要导入的模块
# import sys
# 值为一个列表,存放了一系列的对文件夹
# 其中第一个文件夹是当前执行文件所在的文件夹
# print(sys.path)
# import foo # 内存中已经有foo了
# foo.say()
#
# import time
# time.sleep(10)
#
# import foo
# foo.say()
# 了解:sys.modules查看已经加载到内存中的模块
import sys
# import foo # foo=模块的内存地址
# del foo
# def func():
# import foo # foo=模块的内存地址
#
# func()
#
# # print('foo' in sys.modules)
# print(sys.modules)
import sys
# 找foo.py就把foo.py的文件夹添加到环境变量中
sys.path.append(r'/Users/linhaifeng/PycharmProjects/s14/day21/aa')
# import foo
# foo.say()
from foo import say
执行py文件与导入py文件的区别是什么?
# print(__name__) #
# 1、当foo.py被运行时,__name__的值为'__main__'
# 1、当foo.py被当做模块导入时,__name__的值为'foo'
# if __name__ == '__main__':
# print('文件被执行')
# get()
# change()
# else:
# # 被当做模块导入时做的事情
# print('文件被导入')
# pass
绝对导入和相对导入
# 绝对导入,以包的文件夹作为起始来进行导入
# # import sys
# # print('==========>这是在被导入的__init__.py中查看到的sys.path')
# # print(sys.path)
#
#
# from foo.m1 import f1
# from foo.m2 import f2
# from foo.m3 import f3
#
# from foo.bbb.m4 import f4 # foo内有了一个f4
# # import foo.bbb.m4.f4 # 语法错误,点的左侧必须是一个包
# 相对导入:仅限于包内使用,不能跨出包(包内模块之间的导入,推荐使用相对导入) (顶层包中的文件,想调用子包中的模块,必须用绝对路径。)
# .:代表当前文件夹
# ..:代表上一层文件夹
from .m1 import f1
from .m2 import f2
from .m3 import f3
from .bbb.m4 import f4
# 强调:
# 1、相对导入不能跨出包,所以相对导入仅限于包内模板彼此之间闹着玩
# 而绝对导入是没有任何限制的,所以绝对导入是一种通用的导入方式
包的导入
# 强调:
# 1.关于包相关的导入语句也分为import和from ... import ...
# 两种,但是无论哪种,无论在什么位置,在导入时都必须遵循一个原则:
# 凡是在导入时带点的,点的左边都必须是一个包,否则非法。
# 可以带有一连串的点,如import 顶级包.子包.子模块,但都必须遵循这个原则。但对于导入后,在使用时就没有这种限制了,点的左边可以是包,模块,函数,类(它们都可以用点的方式调用自己的属性)。
# 例如:
# from a.b.c.d.e.f import xxx
# import a.b.c.d.e.f
# 其中a、b、c、d、e 都必须是包
# 2、包A和包B下有同名模块也不会冲突,如A.a与B.a来自俩个命名空间
#
# 3、import导入文件时,产生名称空间中的名字来源于文件,
# import 包,产生的名称空间的名字同样来源于文件,即包下的__init__.py,导入包本质就是在导入该文件
# import foo
# # print(foo.f1)
# # print(foo.f2)
# # print(foo.f3)
# # print(foo.f4)
#
# foo.f4()
# from foo import *
# print(f1)
# print(f2)
# print(f3)
# print(f4)
添加到环境变量
import sys
import os
# sys.path.append(r'C:\DFSInfo.txt')
# print(sys.path)
# BASE_DIR = os.path.dirname(__file__)
# print(BASE_DIR)
# sys.path.append(BASE_DIR)
# from pathlib import Path
#
# root = Path(__file__)
# print(root)
# res = root.parent.parent
# print(res)
强调 : 不要相互导入
纯做记录
这篇写得不错:https://blog.csdn.net/weixin_38256474/article/details/81228492
本文作者:云龙
本文链接:https://www.cnblogs.com/yunlong-study/p/13554730.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步