初识python模块

初识python模块

1. 面向过程编程(理论)

面向过程编程好比在设计一条产品流水线,分布解决问题。
例如用户注册功能

  1. 获取用户名和密码
  2. 组织成固定格式
  3. 文件操作写入文件

设计简单,思路清晰

请看例子:

def get_info():
	username = input('用户名>>>:').strip()
	pwd = input('密码>>>:').strip()
	if len(username)==0 or len(pwd)==0:
		print('用户名或密码不能为空')
		return
	return deal_data(username, pwd)

def deal_data(username, pwd):
	data = '{}|{}\n'.format(username, pwd)
	return save_data(data)

def save_data(data):
	with open(r'userinfo.txt', 'a', encoding='utf8') as f:
		f.wriet(data)
	
get_info()
# 简单的面向过程编程用户注册案例

2. 模块简介

python语言最早起源于Linux运维,被称作胶水语言,调包侠。

  1. 什么是模块???
    模块:一系列功能的结合体

  2. 为什么要用模块???
    为了提升开发效率(站在巨人的肩膀上)

  3. 模块的三种来源

    1. 内置模块(python解释器自带)
    2. 第三方模块(别人写好发布在网上的,基于网络下载再使用)
    3. 自定义模块(自己写的)
  4. 模块的四种表现形式

    1. 使用python编写的代码(.py文件)

    2. 已被编译为共享库或DLL的C或C++扩展。

    3. 包好一组模块的包(文件夹)
      包其实就是多个py文件(模块)的集合。
      包里面通常会含有一个__init__.py文件。

    4. 使用C编写并链接到python解释器的内置模块
      1、3重点掌握

我们学习完模块之后,以后再编写大型项目的时候,遇到一些比较复杂的功能,可以先考虑是否有相应的模块可以调用。

3. import句式

注意:在学习模块的时候,一定要区分谁是导入文件,谁是模块文件。

# 该运行文件名为import句式.py

import md # md,py文件的名字,导入py文件模块文件后缀一定不要加。
# 如果多次导入相同的模块,只会执行一次
"""
我们来看下首次导入md模块时会发生哪些事情
	1.运行导入文件(import句式.py)产生该文件的全局名称空间。
	2.运行md.py文件
	3.产生md.py的全局名称空间,运行md文件内部代码,
	将产生新的名字全部存放于md.py的名称空间。
	4.在导入文件名称空间中产生一个md的名字指向md.py全局名称空间。
"""
# import句式导入模块后
#	通过模块名.点的方式就可以使用到模块中的所有名字,
# 	并且肯定不会产生冲突(指名道姓的找)。

4. from...import...句式

from md import money
# from ... import ...多次导入相同模块也只会执行一次 
"""
导入时会发生:
	1.先产生执行文件的全局名称空间
	2.执行模块文件,产生模块的全局名称空间
	3.将模块中执行之后产生的名字全部存档于模块名称空间中。
	4.在执行文件中有一个money指向模块名称空间中money指向的值。
"""
# from...import...指名道姓的导入某个名字
#	在使用的时候直接写名字即可,但是当前名称空间有相同名字的时候。
#	就会产生冲突,使用的就变成了当前名称空间。

5. 导入模块扩展用法

  1. 起别名,既可以给模块起别名,也可以给模块中某个名字起别名。

    import ssxxxxxxxxx as ssx(别名)
    
    from modddddddd import name as n(别名)
    
  2. 连续导入

    from time, os, sys, json...
    # 导入模块名推荐分开写(除非两个模块功能相似,或者属于同一个系列)
    # 推荐如下:
    import os
    import sys
    import time
    import json
    
    
    from 模块名 import 名字1,名字2,名字3...
    
  3. 通用导入

    from md import *
    # 将md中的所有名字全部导入,主要结合from句式。
    
    # 同时在md.py文件中可以指定别人用*号时可以导入的名字。
    __all__ = ['money', 'read1']  # 列表中为md.py文件中的名字
    
    
  4. 判断文件类型

    # 判断py文件是作为模块文件,还是执行文件
    print(__name__)
    # __name__方法,当文件是执行文件时,会返回__main__,如果文件是被当作模块导入,
    # 则返回文件名(模块名)
    
    if __name__ == '__main__':
    	作为执行文件时运行的代码
    
    """在pycharm中可以直接敲main按tab键即可自动补全上述代码"""
    

6. 循环导入问题

# 运行文件名:循环导入.py
import m1



# 模块文件名:m1.py
print('正在导入m1')
from m2 import y
x = 'm1'



# 模块文件名:m2.py
print('正在导入m2')
from m2 import x
y = 'm2'


--------------------------------------
# 这样在执行运行文件时会报错,出现循环导入的问题
"""
ImportError: cannot import name 'x' from partially 
initialized module 'm1' (most likely due to a circular import)
"""

"""
以后我们在导入模块的时候,如果出现了循环导入的情况,
说明你的程序设计不合理。
通常是不允许出现循环导入现象的!!!!
"""
但是想要一错再错的补救时可以采取如下方法:
	1.调换顺序
		彼此将导入的句式放在代码的最后
	
	2.函数形式
		将导入句式封装到函数内部,等待所有名字加载完毕之后再调用。
		原理都是调换顺序,只是方式不同而已。

7. 模块的导入顺序

  1. 在内存中查找
  2. 内置模块中查找
  3. 系统路径找sys.path(自定义模块)
    如果都没有查找到则报错
# 注意:在给py文件命名时,尽量不要与内置模块冲突。
import sys
print(sys.path)
# 结果中第一个元素永远是当前执行文件所在的路径。

# 当某个自定义模块查找不到的时候
方式一:
	自己动手将该模块添加到sys.path中
	sys.path.append('该模块所在的路径')

方式二:
	from...import...句式
	from 文件夹名称.文件夹名称...import 模块名
	from 文件夹名称.模块名称...import 名字

8. 绝对导入和相对导入

未完待续

初识python模块

上一篇:TVM示例展示 README.md,Makefile,CMakeLists.txt


下一篇:达梦数据库sql优化实践12