模块化编程理念

模块化编程的流程

  1. 设计API,进行功能描述;
  2. 编码实现API中描述的功能;
  3. 在模块中编写测试代码,并消除全局代码;
  4. 使用私有函数实现不被外部客户端调用的模块函数

模块API和功能描述

API:应用程序编程接口,描述模块中提供的函数和类的功能及其使用方法

company = '刘美丽丽人公司'

def yearSalary(monthSalary):
    """根据传入月薪的值,计算出年薪:monthsalary*12"""
    return monthSalary*12

def daySalary(monthSalary):
    """根据传入的月薪值,计算出1天的薪资,一个月按照22.5天计算"""
    return monthSalary/22.5

# __doc__可获得模块的文本说明

调用

import mypy002
print(mypy002.__doc__)
print(mypy002.daySalary.__doc__)

模块的创建和测试代码

__name__获取模块名称,正常情况下,模块名称即为模块的文件名。

print(mypy002.__name__)

当模块作为程序的入口时,其__name__的值为 “main

if __name__ == '__main__':
    print(yearSalary(5000))

模块的导入

在本模块中使用其他模块

impo语句导入

import导入模块
form_import导入模块中的函数
语法:
import 模块名
import 模块1,模块2
import 模块名 as 模块别名 #导入模块并使用新名字

import加载的模块有四个通用类别:

  1. 使用python编写的代码(.py文件)
  2. 已被编译为共享库或DLL的C或C++扩展
  3. 包好一组模块的包
  4. 使用C编写并链接到python解释器的内置模块

导入本质上是导入了一个对象,导入模块实际会生成一个module的对象,使用了内置函数__import__()

模块不论被加载多少次都是一个对象

from … import…导入模块中的一个函数

from math import add

import()动态导入,importlib也可实现动态导入,推荐使用此语句而非__import__()

m =  __import__()
m.pi
a = importlib.import_module(s)
#重新加载模块
import importlib
importlib.reload(mypy002)

包的创建和导入包

包的概念和模块

包相当于一个文件夹,,用于组织管理模块,模块相当于其中的子文件。包中必须包含一个初始化的文件“init.py”,这是包和文件夹的本质区别。包中可以放子包。

包的导入

导入包本质是“导入了包的__init__.py”文件,即执行了__init__.py
init.py文件的三个核心作用:
1.作为包的标识,不能删除
2.用来实现模糊导入: import *(不建议使用)
3.导入包实质是执行__init__.py文件,可以在该文件中做这个包的初始化,以及需要统一执行的代码和批量导入

import a.aa.moda1
from a.aa import moda1

用*导入包

同级目录:使用.
上级目录:使用…

sys.path和模块搜索路径

当导入一个模块时,解释器寻找该模块的顺序为:
1.内置模块
2.当前目录
3.程序的主目录
4.pythonpath目录(如果已经设置了)
5.标准链接库目录
6.第三方库目录(site-packages目录)
7. .pth文件的内容(如果存在的话)
8. sys.path.append()临时添加的目录

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值