模块就是一个包含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函数模块的更多相关文章

  1. python 循环语句 函数 模块

    python循环语句 while循环语法结构 当需要语句不断的重复执行时,可以使用while循环 while expression: while_suite 语句ehile_suite会被连续不断的循 ...

  2. Python(2):创建函数模块

    说明: 在使用python的时候我们除了使用内置的函数之外,可能还需要使用一些别人写的函数.或者我们写的代码也希望可以给其他人使用.要实现这样的功能,我们就需要按照下面的步骤来定义自己的模块: Ste ...

  3. python基础14 ---函数模块5(模块和包)

    模块与包 一.模块 1.模块是怎么诞生的. 在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护.为了编写可维护的代码,我们把很多函数分组,分别放到 不同的文 ...

  4. python基础12 ---函数模块2

    函数模块 一.sys函数模块详解 1.sys.argv[x] 功能:从程序外部接受参数,接收的参数个数可以是多个,在程序内部sys.argv吧这些外部参数转换成元组的形式,然后以索引x的方式在内部取出 ...

  5. python基础11 ---函数模块1

    函数模块 一.函数模块的作用(为什么要有函数模块) 1.函数模块可以减少代码量 2.函数模块方便阅读 3.函数模块维护性强二.函数模块的本质以及调用方法 1.函数模块的本质就是一个.py结尾的文件,该 ...

  6. Python变量/运算符/函数/模块/string

    Python笔记(一) 1.变量类型 Python 有五个内置的简单类型:bool.int.long.float 和 complex.这些类型是不可变的,就是说整数对象一旦创建,其类型便不可更改. t ...

  7. python基础13 ---函数模块3(正则表达式)

    正则表达式 一.正则表达式的本质 1.正则表达式的本质(或 RE)是一种小型的.高度专业化的编程语言,(在Python中)它内嵌在Python中,并通过 re 模块实现.正则表达式模式被编译成一系列的 ...

  8. python基础14 ---函数模块4(configparser模块)

    configparser模块 一.configparser模块 1.什么是configparser模块:configparser模块操作配置文件,配置文件的格式与windows ini和linux的c ...

  9. python之定义参数模块argparse(二)高级使用 --传参为函数的实现

    我们在文章python之定义参数模块argparse的基本使用中介绍了argparse模块的基本使用方法 当前传入的参数只能是int.str.float.comlex类型,不能为函数,这有点不方便,但 ...

随机推荐

  1. TStrings的一些技巧(转)

    TStrings是一个抽象类,在实际开发中,是除了基本类型外,应用得最多的.常规的用法大家都知道,现在来讨论它的一些高级的用法.先把要讨论的几个属性列出来:1.CommaText2.Delimiter ...

  2. 在 windows7 中使用 vs2003 时,“在文件中查找”导致无响应的问题

    解决 Win7 32bit/64bit环境下,在使用VS2003的查找功能时,会导致VS2003无响应. 解决方法:找到VS2003的安装目录,修改"...\Microsoft Visual ...

  3. HDOJ5877(dfs序+离散化+树状数组)

    Weak Pair Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  4. 多线程使用信号量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 ...

  5. mac 在终端使用命令行启动脚本,无法使用自己安装的python去执行脚本问题

    参考了2片文章: //查看python位置 which python //先备份 1.sudo cp /usr/bin/python /usr/bin/python_cp //删除 2.sudo rm ...

  6. JS面向对象编程,对象,属性,方法。

    document.write('<script type="text/javascript" src="http://api.map.baidu.com/api?v ...

  7. ajax级联实现

    效果如下: 选择第一项,第二项.第三项的内容跟着改变. 选择第二项,第三项的内容跟着改变. 第三项则不影响第一项和第二项. 有几点值得提: 1.html到底是前台拼接还是后台拼接. 我选择的是前台拼接 ...

  8. springboot成神之——springboot+mybatis+mysql搭建项目简明demo

    springboot+mybatis+mysql搭建项目简明demo 项目所需目录结构 pom.xml文件配置 application.properties文件配置 MyApplication.jav ...

  9. dubbo学习 一 dubbo概述

    1,背景     1,网站刚开时候的时候可能所有的功能业务都在一个应用里面 2,当业务不断复杂,流量不断增多的时候,就需要将原先的一个应用划分成多个独立的应用. 3,当分出来的业务越来越多的时候,应用 ...

  10. js中slice,splice和split方法的区别

    1.slice(数组) 用法:array.slice(start,end) 解释:该方法是对数组进行部分截取,并返回一个数组副本:参数start是截取的开始数组索引,end参数等于你要取的最后一个字符 ...