面向过程编程与模块

1、面向过程编程

 核心是过程二字,过程是指解决问题的步骤,即先干什么,然后干什么

基于该思想编写程序就好比在设计一条流水线,是一种机械式的思维方式;

优点 :复杂的问题流程化,进而简单化

缺点:扩展性极差

 

2、模块的使用

1、什么是模块?

模块是一些列功能的集合体,常见的模块形式(自定义模块,第三方模块,内置模块):

(1)一个module.py就是一个模块,文件名是module.py,而模块名是module;

(2)一个包含有__init__.py文件的文件夹也是模块

(3)已被编译为共享库或DLL的c或C++扩展

(4)使用c编写并链接到python解释器的内置模块

2、为什么要用模块

(1)用第三方或者内置的模块是一种拿来主义,可以极大的提高开发效率;

(2)自定义模块即将我们自己程序中需要用到的公共的功能写入一个python 文件;然后程序的各部分组件可以通过导入的方式来引用/重用自定义模块中的功能

 

3、如何用模块

导入方式有两种

(1)inport 模块名

import首次导入模块的过程
1、以模块为准创造一个模块的名称空间
2、执行模块对应的文件,将执行过程中产生的名字都丢到模块的名称空间
3、在当前执行文件中拿到一个模块名
import spam
import spam #spam=spam=模块名称空间的内存地址
模块的重复导入会直接引用之前创造好的结果,不会重复执行模块文件

(2)from 模块名 import 具体功能

导入过程:

1,、以模块为准创造一个模块空间

2、执行模块对应的文件,将执行过程中产生的名字都丢到模块的名称空间;

3、在当前执行文件的名称空间中拿到一个名字,该名字直接指向模块中的摸一个名字,可以不用加任何前缀而直接使用

(3)from..import ..对比inport....

优点:不用加前缀,代码更为精简

缺点:容易与当前执行文件中名称空间的名字冲突

相同点:都会执行模块对应的文件,都会产生模块的名称空间;调用功能时需要到定义阶段寻找作用域关系,与调用位置无关

不同点:一种需要加前缀,一种不需要加前缀

 

 

 

4、模块的搜索路径

一个py文件就是一个模块,在导入时必须从某一个文件夹找到该py 文件

模块的搜索路径指的是在导入模块时需要检索的文件夹

导入模块时查找模块的顺序是:

1、先从内存中已经导入的模块中寻找;

2、内置模块;

3、环境变量sys.path中找

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

import sys
print(sys.path) #查找当前执行文件的路径

import sys  #导入sys模块
(sys.path).append(r'F:\object\python2期\day 15') #当前执行文件的路径与所调用的模块路径不一致
# 那么将所调用的模块路径加入环境变量
import mokuai #导入模块
mokuai.index() #导入模块的某一功能

5、软件开发的目录规范
ATM 项目名
bin 可执行文件入口
start 代码
conf 数据库路径,配置信息,所有文件都可以引用
settings
lib 共享功能
common
core 核心逻辑,源代码
src
db 数据文件
db.txt
log 记录日志,操作信息,错误信息
log.txt
Readme 项目使用规范,注意事项介绍



 

posted @ 2018-06-20 15:10  朝朝哥  阅读(603)  评论(0编辑  收藏  举报