python_模块介绍—循环导入与文件类型判断与导入

一、迭代取值与索引取值的差异

l1 = [1, 31, 323, 432]
#索引取值
print(l1[0]) #1
print(l1[1]) #31
print(l1[2]) #323
print(l1[3]) #432
#迭代取值
res = l1.__iter__() 
print(res.__next__()) #1
print(res.__next__()) #31
print(res.__next__()) #323
print(res.__next__()) #432

索引取值:
优势: 可以随意的索取任意数据值
劣势: 只能针对有序的数据类型,无序的容器类型无法取值

迭代取值:
优势: 提供了一种通用的取值方式
劣势: 取值一旦开始只能往前不能回退

ps: 具体使用哪个需要结合实际情况

二、模块简介

python屈辱史:

python刚开始出来的时候被其他编程程序员瞧不起
ps:太简单 写代码都是调用模块(调包侠 贬义词)
随着业务的扩展其他程序员也需要使用python写代码
写完之后发现python真香 贼好用(调包侠 褒义词)
为什么python很牛逼
python之所以牛逼就是因为支持python的模块非常的多 非常的全 非常的猛
作为一名python程序员
将来接收到某个业务需求的时候 不要上来就想着自己写 先看看有没有相应的模块已经实现

1.如何理解模块

模块是一系列功能的结合
使用模块相当于拥有了结合体的所有功能
ps: 使用模块相当于站在巨人肩膀上

2.模块的分类

① 内置模块
解释器自带,直接可以使用

eg:
	import time
	time.sleep(2)

② 自定义模块
自己写的模块

eg:
	注册功能  登录功能

③ 第三方模块
别人写的模块,存在于网络上,提前下载使用

eg:
	图形识别 图形可视化 语音识别

3.模块的表现形式

① py文件 (也称模块文件)
② 含有多个py文件的文件夹 (按照模块功能的不同划分不同的文件夹存储)
③ 已被编译为共享库或DLL的c或C++扩展(了解)
④ 使用C编写并链接到python解释器的内置模块(了解)

三、导入模块的两种句式

补充说明
以后真正的项目中 所有的py文件名称都是英文
没有所谓的编号和中文
eg:
错误的:01.变量的使用
正确的:test01.py
学习模块的时候,模块文件的名称就得用英文
py文件被当做模块导入的时候不需要考虑后缀

导入模块的句式1 import句式

import md

import md
执行文件是 02 模块的导入句式.py
被导入文件是 md.py
1.产生正在操作文件的全局名称空间
2.产生被导入文件模块的全局名称空间
3.立刻运行导入文件中的所有文件并存到该名称空间中
4.执行操作文件md后面导入文件的内容
5.

补充说明
同一个程序反复导入相同的模块 导入语句只会执行一次

import md 有效
import md 无效
import md 无效

 money = 10
    print(md.money)
    print(money)


    def read1():
       print('我是执行文件里面的read函数')
    md.read2()

    money = 1000
    md.change()
    print(money)
    print(md.money)

导入模块的句式2 from…import…句式

from md import …

 # from md import money  # 指名道姓的导入
# print(money)  # 999
# money = '嘿嘿嘿'
# print(money)  # 嘿嘿嘿
# print(read1)
# print(md.read1())
from md import money, read1
    read1()
    """
    1.创建执行文件的名称空间
    2.创建被导入文件的名称空间
    3.执行被导入文件中的代码 将产生的名字存储到被导入文件的名称空间中
    4.在执行文件中获取到指定的名字 指向被导入文件的名称空间
    """

四、两种导入句式的优缺点

import mdfrom md import money, read1
优点通过md点的方式可以使用到模块内所有的名字,并且不会冲突指名道姓的使用指定的名字,并且不需要加模块名前缀
缺点md什么都可以点,有时候并不想让所有的名字都能被使用名字及其容易产生冲突(绑定关系被修改)

五、补充知识

1.起别名

情况1:多个模块文件名相同(多个人写)
    from md import money as md_my
    from md1 import money as md1_my
    print(md_my)
    print(md1_my)
情况2:原有的模块文件名复杂
   	import mdddddddddd as md

2.导入多个名字

import time, sys, os
上述导入方式建议多个模块功能相似才能适应 不相似尽量分开导入
import time
import os
import sys

from md import money, read1, read2	
上述导入方式是推荐使用的 因为多个名字出自于一个模块文件

3.全导入

需求:需要使用模块名称空间中很多名字 并且只能使用from...import句式
from md import *  # *表示所有
ps:针对*号的导入还可以控制名字的数量
在模块文件中可以使用__all__ = [字符串的名字]控制*能够获取的名字

六、循环导入问题

如何理解循环导入
循环导入就是两个文件彼此导彼此
循环导入容易出现报错现象
使用彼此的名字可能是在没有准备好的情况下就使用了
如何解决循环导入保存现象
彼此在使用彼此名字之前 先准备好

“”“循环导入将来尽量避免出现!!! 如果真的避免不了 就想办法让所有的名字在使用之前提前准备好”“”

七、判断文件类型

学习完模块之后 以后我们的程序运行起来可能涉及到的文件就不止一个

所有的py文件中都自带一个__name__内置名
当py文件是执行文件的时候 name__的结果是__main
当py文件是被导入文件的时候 __name__的结果是模块名(文件名)

__name__主要用于开发模块的作者测试自己的代码使用
if name == ‘main’:
当文件是执行文件的时候才会执行if的子代码

上述判断一般只出现整个程序的启动文件中

ps:在pycharm中可以直接编写main按tab键自动补全

八、模块的查找顺序

1.先去内存中查找
2.再去内置中查找
3.再去sys.path中查找(程序系统环境变量)

下面详细的讲解

1.导入一个文件 然后在导入过程中删除该文件 发现还可以使用

import md
import time

time.sleep(15)
print(md.money)

2.创建一个跟内置模块名相同的文件名

# import time
# print(time.time())
from time import name
print(name)

ps:创建模块文件的时候尽量不要与内置模块名冲突

3.导入模块的时候一定要知道谁是执行文件

所有的路径都是参照执行文件来的
 import sys
sys.path.append(r'D:\pythonProject\day22\xxx')
import mdd
print(mdd.name)

1.通用的方式 sys.path.append(目标文件所在的路径)
2.利用from…import句式 起始位置一定是执行文件所在的路径

  • 附加:python模块导入的方法
import ..         #导入整个模块
from .. import ..     #导入模块中的类、函数或者变量
from .. import *      #导入模块中的所有公开成员
from .. import .. as ..  #这个是给导入的成员取个别名

一般有md,后面print的值都是在导入文件的全局名称空间
而没有md,后面print的值在正在操作文件的全局名称空间

![在这里插入图片描述](https://img-blog.csdnimg.cn/6a23c6991dc34e1cae1dbc0699a4f4ed.png#pic_center在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值