之前跟大家讲的是一些python的数据基础,从这篇文章开始,我们开始正式学习python的模块化编程

下面我们解释一下什么叫做模块

之前已经讲过怎么去定义一个方法,如果你是用python交互器(自带交互器,或者是ipython)来学习定义方法的话,你定义完方法后,然后退出交互器,然后你再来使用这个方法,很显然,是不会成功调用的,这是因为python交互器在你退出后,会清空内存,所有定义的变量和方法都会被清理

如果你想把定义好的方法用在你的新脚本文件中,这样就必须引入一种模块机制

你可以把你写好的python代码保存到一个文件中(当然是以" .py "结尾的文件), 那么这样你就可以长久的使用这个代码中的方法和变量

一个新文件想要使用之前保存好的文件的方法,就必须通过import方法导入这个文件

import

import的方法是用来做模块导入的,他主要有以下几种使用形式

导入整个模块

In [1]: import sys

In [2]: sys.path
Out[2]:
['',
'D:\\Users\\susmote\\Anaconda3\\Scripts',
'D:\\Users\\susmote\\Anaconda3\\python36.zip',
'D:\\Users\\susmote\\Anaconda3\\DLLs',
'D:\\Users\\susmote\\Anaconda3\\lib',
'D:\\Users\\susmote\\Anaconda3',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\Babel-2.5.0-py3.6.egg',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\win32',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\win32\\lib',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\Pythonwin',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\IPython\\extensions',
'C:\\Users\\susmote\\.ipython']

  

导入模块中的某个方法

In [1]: from sys import path

In [2]: path
Out[2]:
['',
'D:\\Users\\susmote\\Anaconda3\\Scripts',
'D:\\Users\\susmote\\Anaconda3\\python36.zip',
'D:\\Users\\susmote\\Anaconda3\\DLLs',
'D:\\Users\\susmote\\Anaconda3\\lib',
'D:\\Users\\susmote\\Anaconda3',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\Babel-2.5.0-py3.6.egg',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\win32',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\win32\\lib',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\Pythonwin',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\IPython\\extensions',
'C:\\Users\\susmote\\.ipython']

  from 后面接模块名,import后面接具体的方法,可以接多个,用逗号隔开即可

直接导入所有方法

In [1]: from sys import *

In [2]: path
Out[2]:
['',
'D:\\Users\\susmote\\Anaconda3\\Scripts',
'D:\\Users\\susmote\\Anaconda3\\python36.zip',
'D:\\Users\\susmote\\Anaconda3\\DLLs',
'D:\\Users\\susmote\\Anaconda3\\lib',
'D:\\Users\\susmote\\Anaconda3',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\Babel-2.5.0-py3.6.egg',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\win32',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\win32\\lib',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\Pythonwin',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\IPython\\extensions',
'C:\\Users\\susmote\\.ipython']

  

上面的使用根据具体情况而定

自己定义模块

之前在讲定义方法的时候讲到了斐波那契数列,这一次,我们还是用他做例子

首先在文本编辑器中写下这几段代码

  保存为fibo.py

然后我们继续在这个目录打开python交互器

In [1]: import fibo

In [2]: fibo.fib(200)
0 1 1 2 3 5 8 13 21 34 55 89 144 In [3]: fibo.fib2(200)
Out[3]: [0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144]

  可以直接导入之前写好的python代码,调用里面写好的方法

__name__变量

__name__是一个系统变量,他可以显示当前函数执行过程中的名称

简单来说__name__就是全局的模块名称

例如上面那个例子

In [1]: import fibo

In [2]: fibo.fib(200)
0 1 1 2 3 5 8 13 21 34 55 89 144 In [3]: fibo.fib2(200)
Out[3]: [0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144] In [4]: fibo.__name__
Out[4]: 'fibo'

  

在后面我们会经常用到这样一个表达式

if __name__ = __main__:

  全局代码都写在这行代码的后面,也就是说,在执行代码的时候会首先判断是不是在本地执行的,简单来说,他保证了你的代码只能在你的文件中运行

模块路径更改

接下来我们要讲到的这个就非常重要了,在之前我们添加的python文件和导入模块都是在同一个目录进行的,所以会成功执行

但是如果我们要导入其他路径的python文件,这就有点麻烦了

首先我们要熟悉一个命令

In [1]: import sys

In [2]: sys.path
Out[2]:
['',
'D:\\Users\\susmote\\Anaconda3\\Scripts',
'D:\\Users\\susmote\\Anaconda3\\python36.zip',
'D:\\Users\\susmote\\Anaconda3\\DLLs',
'D:\\Users\\susmote\\Anaconda3\\lib',
'D:\\Users\\susmote\\Anaconda3',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\Babel-2.5.0-py3.6.egg',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\win32',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\win32\\lib',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\Pythonwin',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\IPython\\extensions',
'C:\\Users\\susmote\\.ipython']

  之前多次使用过的命令

这个命令会显示所有的python模块的位置,以一个列表返回,通俗一点来讲,就是python解释器会去这些路径去寻找python的文件,也就每个模块

比如numpy这个模块文件的路径

如果我们要添加自己的模块到路径中,就可以使用append方法(前面说过sys.path是一个列表)

例如下面这行代码

In [5]: sys.path.append("E:\\Python-project\\Python-project\\module_study")

In [6]: sys.path
Out[6]:
['',
'D:\\Users\\susmote\\Anaconda3\\Scripts',
'D:\\Users\\susmote\\Anaconda3\\python36.zip',
'D:\\Users\\susmote\\Anaconda3\\DLLs',
'D:\\Users\\susmote\\Anaconda3\\lib',
'D:\\Users\\susmote\\Anaconda3',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\Babel-2.5.0-py3.6.egg',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\win32',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\win32\\lib',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\Pythonwin',
'D:\\Users\\susmote\\Anaconda3\\lib\\site-packages\\IPython\\extensions',
'C:\\Users\\susmote\\.ipython',
'E:\\Python-project\\Python-project\\module_study']

注意在输入路径时要注意转义字符,路径已经成功加入到了列表中了

下面我们测试有没有成功生效,还是导入我们之前定义的斐波那契数列的代码

首先随便进入一个目录,比如进入C盘

然后再进入python交互器

In [7]: import fibo

In [8]: fibo.fib(200)
0 1 1 2 3 5 8 13 21 34 55 89 144 In [9]: fibo.fib2(200)
Out[9]: [0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144] In [10]: fibo.__name__
Out[10]: 'fibo'

  

可以成功导入

关于模块简单的就是这些,多练才能孰能生巧

官方博客 www.susmote.com

15_Python模块化编程_Python编程之路的更多相关文章

  1. 01-Python的介绍_Python编程之路

    首先用一句业内非常出名的话来介绍Python "人生哭短,我用Python" 这也是Python宣传时经常说的一句话 从这句话中,可以非常清楚Python他到底优点在哪里,为什么要 ...

  2. 07_Python的控制判断循环语句1(if判断,for循环...)_Python编程之路

    Python的数据类型在前几节我们都简单的一一介绍了,接下来我们就要讲到Python的控制判断循环语句 在现实编程中,我们往往要利用计算机帮我们做大量重复计算的工作,在这样的情况下,需要机器能对某个条 ...

  3. 09_Python定义方法_Python编程之路

    有关Python判断与循环的内容我们上几节已经跟大家一起学习了,这一节我们主要针对def 做一个讲解 def 定义一个方法 在项目编程中,我们往往要做很多重复的事,比如一个排序的功能(当然Python ...

  4. 02-Python的下载和安装_Python编程之路

    原文发布在特克斯博客www.susmote.com 之前给大家讲了关于python的背景知识,还有Python的优点和缺点,相信通过之前的介绍很多人已经清楚自己到底要不要选择学习Python,如果已经 ...

  5. 03-第一个脚本程序以及输入输出_Python编程之路

    上节课已经教大家安装了Python的解释器,那么这节课我们就可以正式来写代码了 说明:在下面的代码演示中,我将大部分使用python交互器演示代码的输入输出,注意">>>& ...

  6. 04_Python的数据类型1数值和字符串_Python编程之路

    上一节我们通过一个helloworld程序学习python的一些简单操作,还有输入与输出 这节我们来讲Python的数据类型与变量的操作 Python的交互器 在讲这个之前,我要先讲一下python的 ...

  7. 06_Python的数据类型3元组,集合和字典_Python编程之路

    上一节跟大家讲了Python的列表,当然不是完整的讲完,后续我们还会提到,这一节我们还是来讲Python的数据类型 首先要讲到的就是元组 元组其实拥有列表的一些特性,可以存储不同类型的值,但在某些方面 ...

  8. 10_Python函数方法加深_Python编程之路

    上节课已经简单的跟大家讲了如何定义一个方法,但是并没有深入去讲,这一节我们继续来学习定义方法中需要注意的几点 默认参数 前面我们讲到定义一个方法时是可以传递参数的,除了这个功能,实际上python在定 ...

  9. 11_Python的列表推导式_Python编程之路

    上一节我们结束了有关python的方法相关内容 这一节我们先来学习python的列表推导式 之前跟大家说过range方法的使用,在这里我就不做过多的解释了,如忘记了,请翻阅之前的介绍 列表推导式,是P ...

随机推荐

  1. SpringBoot入门:Spring Data JPA 和 JPA(理论)

    参考链接: Spring Data JPA - Reference Documentation Spring Data JPA--参考文档 中文版 纯洁的微笑:http://www.ityouknow ...

  2. Spark入门(1-1)什么是spark,spark和hadoop

    一.Spark是什么? Apache Spark 是专为大规模数据处理而设计的快速通用的计算引擎,可用来构建大型的.低延迟的数据分析应用程序. Spark是UC Berkeley AMP lab (加 ...

  3. SpringCloud的EurekaClient : 客户端应用访问注册的微服务(有断路器场景)

    演示客户端应用如何访问注册在EurekaServer里的微服务 一.概念和定义 采用Ribbon或Feign方式访问注册到EurekaServer中的微服务.1.Ribbon实现了客户端负载均衡,2. ...

  4. leetcode算法: Find Bottom Left Tree Value

    leetcode算法: Find Bottom Left Tree ValueGiven a binary tree, find the leftmost value in the last row ...

  5. beautiful soup

    beautiful soup是一个可以从html或者xml文件中提取数据的python库,它能够通过你喜欢的转换器实现惯用的文档导航.查找.修改文档的方式. beautiful soup 会帮你节省数 ...

  6. 定义一个方法get_page(url),url参数是需要获取网页内容的网址,返回网页的内容。提示(可以了解python的urllib模块)

    定义一个方法get_page(url),url参数是需要获取网页内容的网址,返回网页的内容.提示(可以了解python的urllib模块) import urllib.request def get_ ...

  7. js分页效果

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. 【贪心】Codeforces 349B.Color the Fence题解

    题目链接:http://codeforces.com/problemset/problem/349/B 题目大意 小明要从9个数字(1,2,--,9)去除一些数字拼接成一个数字,是的这个数字最大. 但 ...

  9. [Other] Nuget 构建服务器与常用命令

    公司出于某些原因需要自己在内部网络搭建一个私有的 Nuget 服务器,而且要运行在 Linux服务器上面.如果说 Windows 下搭建的话很简单,直接在项目当中引入 Nuget 的库就 OK,这儿的 ...

  10. 前端性能监控系统 & 前端数据分析系统

    前端监控系统 目前已经上线,欢迎使用! 背景:应工作要求,需要整理出前端项目的报错信息,尝试过很多统计工具,如: 腾讯bugly.听云.OneApm.还有一个忘记名字的工具. 因为各种原因,如: 统计 ...