Head First Python之2函数模块
模块就是一个包含Python代码的文本文件,以.py结尾。
第三方模块都在PyPI(python package index)上,可使用PyPI发布你的模块,供他人使用。
注释代码
# coding=utf-8 """
nester.py模块
模块描述放在这里
""" def print_lol(li):
"""
描述函数放在这里
:param li: list
:return: None
"""
for each in li:
if isinstance(each, list):
print_lol(each)
else:
print(each)
发布到PyPI
1、为模块创建各一个文件夹nester_zlm
文件夹下面包含nester.py和setup.py
setup.py包含发布的元数据,代码如下:
from distutils.core import setup setup(
name='nester',
version='1.0.0',
py_modules=['nester'],
author='hfpython',
author_email='zlm_dj68@163.com',
url='http://www.findeen.co.uk/headfirstlabs.com.html',
description='a Simple printer of nested lists',
)
2、构建一个发布文件
nester_zlm文件夹中打开一个终端窗口,键入命令:python3 setup.py sdist
3、将发布安装到你的Python本地副本中
python3 setup.py install
安装成功后发布已经准备就绪
4、发布速览
build和dist的是发布工具生成的。
5、导入模块并使用
导入新创建的模块nester,定义一个列表,调用print_lol函数,没有加命名空间时,会导致NameError;
用命名空间限定函数名后,pass。
若使用 from nester import print_lol,则可以不用命名空间,但要注意,如果当现有空间存在print_lol,那么导入的函数会覆盖现有的函数。
6、注册Pypi网站
https://pypi.python.org/pypi?%3Aaction=register_form
PGP Key一般都不用填
7、向pypi上传代码
(1)通过命令行窗口注册Pypi
pyton3 setup.py register
(2)通过命令行窗口上传
python3 setup.py sdist upload
(当然,如果试图上传一个名字为nester的模块,会得到一个错误,指出这个模块名字已经被占用)
添加参数
新的需求
现在有新的需求,nester.py模块的print_lol函数,当碰到一个嵌套列表时,需要有缩进,以让层次跟清晰。
这时需要添加额外的参数控制行为
# coding=utf-8 def print_lol(the_list, level):
"""
所提供列表中的各个数据项会(递归地)打印到屏幕上,而且各占用一行
:param the_list: 包含或者不包含嵌套列表的列表
:param level:用来在遇到嵌套列表时插入制表符
:return: None
"""
for each in the_list:
if isinstance(each, list):
print_lol(each, level+1)
else:
for tab_stop in range(level):
print("\t", end="")
print(each) if __name__ == '__main__':
li = [1, [2, 3], 4]
print_lol(li, 0)
运行结果:
将上述代码更新到pypi
1、修改setup.py中version='1.1.0',
2、发布 python3 setup.py sdist upload
可选参数
上述nester.py模块有个问题,无法兼容老版本,此时我们可以用可选参数
为了实现可选参数,需要位这个参数提供一个缺省值,如下:
def print_lol(the_list, level=0):
这样,我们使用以下两种都是一样的了:
print_lol(li)
print_lol(li, 0)
API还是不对
上述nester.py模块还有个问题,并不是所有人都想有缩进,那如何兼容不带缩进呢
再添加一个新的变量
# coding=utf-8 def print_lol(the_list, indent=False, level=0):
"""
所提供列表中的各个数据项会(递归地)打印到屏幕上,而且各占用一行
:param indent: False-不打开缩进,True-打开缩进
:param the_list: 包含或者不包含嵌套列表的列表
:param level:用来在遇到嵌套列表时插入制表符
:return: None
"""
for each in the_list:
if isinstance(each, list):
print_lol(each, indent, level+1)
else:
if indent:
for tab_stop in range(level):
print("\t", end="")
print(each) if __name__ == '__main__':
li = [1, [2, 3], 4]
print_lol(li, True)
Head First Python之2函数模块的更多相关文章
- python 循环语句 函数 模块
python循环语句 while循环语法结构 当需要语句不断的重复执行时,可以使用while循环 while expression: while_suite 语句ehile_suite会被连续不断的循 ...
- Python(2):创建函数模块
说明: 在使用python的时候我们除了使用内置的函数之外,可能还需要使用一些别人写的函数.或者我们写的代码也希望可以给其他人使用.要实现这样的功能,我们就需要按照下面的步骤来定义自己的模块: Ste ...
- python基础14 ---函数模块5(模块和包)
模块与包 一.模块 1.模块是怎么诞生的. 在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护.为了编写可维护的代码,我们把很多函数分组,分别放到 不同的文 ...
- python基础12 ---函数模块2
函数模块 一.sys函数模块详解 1.sys.argv[x] 功能:从程序外部接受参数,接收的参数个数可以是多个,在程序内部sys.argv吧这些外部参数转换成元组的形式,然后以索引x的方式在内部取出 ...
- python基础11 ---函数模块1
函数模块 一.函数模块的作用(为什么要有函数模块) 1.函数模块可以减少代码量 2.函数模块方便阅读 3.函数模块维护性强二.函数模块的本质以及调用方法 1.函数模块的本质就是一个.py结尾的文件,该 ...
- Python变量/运算符/函数/模块/string
Python笔记(一) 1.变量类型 Python 有五个内置的简单类型:bool.int.long.float 和 complex.这些类型是不可变的,就是说整数对象一旦创建,其类型便不可更改. t ...
- python基础13 ---函数模块3(正则表达式)
正则表达式 一.正则表达式的本质 1.正则表达式的本质(或 RE)是一种小型的.高度专业化的编程语言,(在Python中)它内嵌在Python中,并通过 re 模块实现.正则表达式模式被编译成一系列的 ...
- python基础14 ---函数模块4(configparser模块)
configparser模块 一.configparser模块 1.什么是configparser模块:configparser模块操作配置文件,配置文件的格式与windows ini和linux的c ...
- python之定义参数模块argparse(二)高级使用 --传参为函数的实现
我们在文章python之定义参数模块argparse的基本使用中介绍了argparse模块的基本使用方法 当前传入的参数只能是int.str.float.comlex类型,不能为函数,这有点不方便,但 ...
随机推荐
- TStrings的一些技巧(转)
TStrings是一个抽象类,在实际开发中,是除了基本类型外,应用得最多的.常规的用法大家都知道,现在来讨论它的一些高级的用法.先把要讨论的几个属性列出来:1.CommaText2.Delimiter ...
- 在 windows7 中使用 vs2003 时,“在文件中查找”导致无响应的问题
解决 Win7 32bit/64bit环境下,在使用VS2003的查找功能时,会导致VS2003无响应. 解决方法:找到VS2003的安装目录,修改"...\Microsoft Visual ...
- HDOJ5877(dfs序+离散化+树状数组)
Weak Pair Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- 多线程使用信号量sem_init,sem_wait,sem_post
信号量的主要函数有: int sem_init(sem_t *sem,int pshared,unsigned int value); int sem_wait(sem_t *sem); int se ...
- mac 在终端使用命令行启动脚本,无法使用自己安装的python去执行脚本问题
参考了2片文章: //查看python位置 which python //先备份 1.sudo cp /usr/bin/python /usr/bin/python_cp //删除 2.sudo rm ...
- JS面向对象编程,对象,属性,方法。
document.write('<script type="text/javascript" src="http://api.map.baidu.com/api?v ...
- ajax级联实现
效果如下: 选择第一项,第二项.第三项的内容跟着改变. 选择第二项,第三项的内容跟着改变. 第三项则不影响第一项和第二项. 有几点值得提: 1.html到底是前台拼接还是后台拼接. 我选择的是前台拼接 ...
- springboot成神之——springboot+mybatis+mysql搭建项目简明demo
springboot+mybatis+mysql搭建项目简明demo 项目所需目录结构 pom.xml文件配置 application.properties文件配置 MyApplication.jav ...
- dubbo学习 一 dubbo概述
1,背景 1,网站刚开时候的时候可能所有的功能业务都在一个应用里面 2,当业务不断复杂,流量不断增多的时候,就需要将原先的一个应用划分成多个独立的应用. 3,当分出来的业务越来越多的时候,应用 ...
- js中slice,splice和split方法的区别
1.slice(数组) 用法:array.slice(start,end) 解释:该方法是对数组进行部分截取,并返回一个数组副本:参数start是截取的开始数组索引,end参数等于你要取的最后一个字符 ...