python中的函数用法入门教程

本文较为详细的讲述了Python程序设计中函数的用法,对于Python程序设计的学习有不错的借鉴价值。具体分析如下:

一、函数的定义:

Python中使用def关键字定义函数,函数包括函数名称和参数,不需要定义返回类型,Python能返回任何类型:

#没有返回值的函数,其实返回的是None
def run(name):
    print name,'runing' #函数体语句从下一行开始,并且第一行必须是缩进的 

>>>run('xiaoming')
xiaoming runing 

>>>print run('xiaoming')
xiaoming runing
None #如果没有ruturn语句,函数返回的是None 

#有返回值的参数
def run(name):
    return name+'runing'
>>>r = run('xiaoming')
>>>r
xiaoming runing

二、 文档字符串:

在Python中注释是用#来表示的,暂时没有发现多行注释的写法。不过在函数内部可以使用多行字符串来写:

def run(name):
    """ print somebody runing"""#写在函数体的第一行才叫文档字符串
    print name,'runing'

可以使用__doc__查看函数的文档字符串内容

>>>run.__doc__
print somebody runing

三、参数:

Python的函数的参数列表可以是任意多个,调用函数的时候,采取位置绑定和关键字绑定两种方式,确认传入的变量对应的参数!

上面演示的代码,都可以看作是位置绑定 。

下面看一下关键字绑定 :

def run(name,age,sex):
    print 'name :',name,'age:',age,'sex:',sex
>>> run(age=23,name='xiaoming',sex='boy')#关键字绑定
name:xiaoming age:23 sex:boy

某个参数不能在一次调用中同时使用位置和关键字绑定

def run(name,age,sex):
    print 'name :',name,'age:',age,'sex:',sex
>>> run('xiaoming',name='xiaoming',sex='boy')
SyntaxError: non-keyword arg after keyword arg

函数调用的时候,如果第一个参数使用了关键字绑定,后面的参数也必须使用关键字绑定!

默认参数 :

def run(name,age=20,sex='girl'):
    print name,age,sex
>>>run('nana')
nana 20 girl
>>>run('nana',23)
nana 23 girl
>>>run('gg','boy')#使用的位置绑定,所以,python为将'boy'绑定在age上,而不是我们想要的sex上
gg boy girl 

>>>run('gg',sex='boy')#混合关键字绑定,可以实现想要的效果
gg 20 boy

1、 如果一个函数的参数中含有默认参数,则这个默认参数后的所有参数都必须是默认参数,否则会抛出:SyntaxError: non-default argument follows default argument的异常。

def run(name,age=10,sex):
    print name ,age ,sex
SyntaxError: non-default argument follows default argument gg 23 boy

几个异常

def run(name,age,sex='boy'):
    print name,age,sex 

>>>run()#required argument missing
>>>run(name='gg',23)#non-keyword argument following keyword
>>>run('gg',name='pp')#duplicate value for argument
>>>run(actor='xxxx')#unknown keyword

#第一种情况是丢失参数 
#第二种情况是:如果第一个使用了keyword绑定,后面的都必须使用keyword绑定 
#第三种情况:在一次调用中不能同时使用位置和keyword绑定 
#第四种情况:不能使用参数列表外的关键字

2、默认参数在函数定义段被解析,且只解析一次 。

>>>i = 5
>>>def f(arg=i):
>>>  print arg
>>>i = 6
>>>f()
5 #结果是5

当默认值是一个可变对象,诸如链表、字典或大部分类实例时,会产生一些差异:

>>> def f(a, L=[]):
>>>  L.append(a)
>>>  return L 

>>> print f(1)
>>> print f(2)
>>> print f(3)
[1]
[1, 2]
[1, 2, 3] 

#可以用另外一种方式实现:
>>> def f(a, L=None):
>>>  if L is None:
>>>    L = []
>>>  L.append(a)
>>>  return L

可变参数

参数被包装进一个元组。在这些可变个数的参数之前,可以有零到多个普通的参数:

def run(name,*args):
    print name,'runing'
    for a in args : print a 

>>> run('gg','mm')
gg runing
mm
>>> run('gg',1,2,'mm')
gg runing
1
2
mm
>>> run('gg',1,1.02,['mm','gm'])
gg runing
1
1.02
['mm','gm']

可见可变参数可以是任意多个,而且是任意类型(并且能混合使用)

关键字绑定的可变参数 (**args这种形式,看原文档,不甚理解,暂且这样叫)

def run(name,**args):
    keys = args.keys()
    for k in keys :
       print k,args[k] 

>>> run('nana',type='open')
type open
>>> run('nana',type='open',title='gogo')
type open
title gogo 

#*arg 必须在**args的前面
def run(name,*arg,**args):
    for a in arg :print a
    keys = args.keys()
    for k in keys :
       print k,args[k]
>>> run('nn','mm',1,2,'oo',type='open',title='gogo')
mm
1
2
oo
type open
title gogo

参数列的分拆

>>> range(3, 6)       # normal call with separate arguments
[3, 4, 5]
>>> args = [3, 6]
>>> range(*args)      # call with arguments unpacked from a list
[3, 4, 5]

通过 lambda 关键字,可以创建短小的匿名函数

>>> def make_incrementor(n):
...   return lambda x: x + n #相当于创建了一个一x为参数的匿名函数?
...
>>> f = make_incrementor(42)#f = make_incrementor(n=42),设置n的值
>>> f(0)#其实调用的是匿名函数?
42
>>> f(1)
43 

#看下面一个例子报的错误就可以明白一点了
>>>def t(n):
...     print x*n
>>>m = t(2)
Traceback (most recent call last):
 File "<pyshell#85>", line 1, in <module>
  m = t(2)
 File "<pyshell#84>", line 2, in t
  print x*n
NameError: global name 'x' is not defined

说是没有定义全局name 'x'

>>> x =10
>>> def t(n):
...    print x*n
>>> m = t(2)
20

希望本文所述对大家的Python程序设计有所帮助

(0)

相关推荐

  • python 读写、创建 文件的方法(必看)

    python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd() 返回指定目录下的所有文件和目录名:os.listdir() 函数用来删除一个文件:os.remove() 删除多个目录:os.removedirs(r"c:\python") 检验给出的路径是否是一个文件:os.path.isfile() 检验给出的路径是否是一个目录:os.path.isdir() 判断是否是绝对路

  • Python入门_学会创建并调用函数的方法

    这篇文章主要介绍下如何创建并调用函数. print():是打印放入对象的函数 len():是返回对象长度的函数 input():是让用户输入对象的函数 ... 简单来说,函数就是将对象放进去,然后就可以得到处理结果.在Python中有很多自带函数,具体可以参见此链接: https://docs.python.org/3/library/functions.html Python自带的函数有限,想要解决更多的问题,我们需要学会自己创建函数. def(即define):指定义一个函数 arg(即ar

  • Python自定义函数的创建、调用和函数的参数详解

    函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段.函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也可以自己创见函数,这被叫做用户自定义函数.一.定义一个函数你可以定义一个由自己想要功能的函数,以下是简单的规则: 1.函数代码块以def关键词开头,后接函数标识符名称和圆括号().2.任何传入参数和自变量必须放在圆括号中间.圆括号之间可以用于定义参数.3.函数的第一行语句可以选择性地使用文档字符串-用于存放函数说明.4.

  • python中的函数用法入门教程

    本文较为详细的讲述了Python程序设计中函数的用法,对于Python程序设计的学习有不错的借鉴价值.具体分析如下: 一.函数的定义: Python中使用def关键字定义函数,函数包括函数名称和参数,不需要定义返回类型,Python能返回任何类型: #没有返回值的函数,其实返回的是None def run(name): print name,'runing' #函数体语句从下一行开始,并且第一行必须是缩进的 >>>run('xiaoming') xiaoming runing >&

  • Python中zip()函数用法实例教程

    本文实例讲述了Python中zip()函数的定义及用法,相信对于Python初学者有一定的借鉴价值.详情如下: 一.定义: zip([iterable, ...]) zip()是Python的一个内建函数,它接受一系列可迭代的对象作为参数,将对象中对应的元素打包成一个个tuple(元组),然后返回由这些tuples组成的list(列表).若传入参数的长度不等,则返回list的长度和参数中长度最短的对象相同.利用*号操作符,可以将list unzip(解压). 二.用法示例: 读者看看下面的例子,

  • Python中super函数用法实例分析

    本文实例讲述了Python中super函数用法.分享给大家供大家参考,具体如下: 这是个高大上的函数,在python装13手册里面介绍过多使用可显得自己是高手 23333. 但其实他还是很重要的. 简单说, super函数是调用下一个父类(超类)并返回该父类实例的方法. 这里的下一个的概念参考后面的MRO表介绍. help介绍如下: super(type, obj) -> bound super object; requires isinstance(obj, type) super(type)

  • Python中property函数用法实例分析

    本文实例讲述了Python中property函数用法.分享给大家供大家参考,具体如下: 通常我们在访问和赋值属性的时候,都是在直接和类(实例的)的__dict__打交道,或者跟数据描述符等在打交道.但是假如我们要规范这些访问和设值方式的话,一种方法是引入复杂的数据描述符机制,另一种恐怕就是轻量级的数据描述符协议函数Property().它的标准定义是: + property(fget=None,fset=None,fdel=None,doc=None) + 前面3个参数都是未绑定的方法,所以它们

  • Python中Scrapy框架的入门教程分享

    目录 前言 安装Scrapy 创建一个Scrapy项目 创建一个爬虫 运行爬虫 结论 前言 Scrapy是一个基于Python的Web爬虫框架,可以快速方便地从互联网上获取数据并进行处理.它的设计思想是基于Twisted异步网络框架,可以同时处理多个请求,并且可以使用多种处理数据的方式,如提取数据.存储数据等. 本教程将介绍如何使用Scrapy框架来编写一个简单的爬虫,从而让您了解Scrapy框架的基本使用方法. 安装Scrapy 首先,您需要在您的计算机上安装Scrapy框架.您可以使用以下命

  • Python中max函数用法实例分析

    本文实例讲述了Python中max函数用法.分享给大家供大家参考.具体如下: 这里max函数是Python内置的函数,不需要导入math模块 # 最简单的 max(1, 2) max('a', 'b') # 也可以对列表和元组使用 max([1,2]) max((1,2)) # 还可以指定comparator function max('ah', 'bf', key=lambda x: x[1]) def comparator(x): return x[1] max('ah', 'bf', ke

  • python中Genarator函数用法分析

    本文实例讲述了python中Genarator函数用法.分享给大家供大家参考.具体如下: Generator函数的定义与普通函数的定义没有什么区别,只是在函数体内使用yield生成数据项即可.Generator函数可以被for循环遍历,而且可以通过next()方法获得yield生成的数据项. def func(n): for i in range(n): yield i for i in func(3): print i r=func(3) print r.next() print r.next

  • python中enumerate函数用法实例分析

    本文实例讲述了python中enumerate函数用法.分享给大家供大家参考.具体分析如下: 今日发现一个新函数 enumerate .一般情况下对一个列表或数组既要遍历索引又要遍历元素时,会这样写: for i in range (0,len(list)): print i ,list[i] 但是这种方法有些累赘,使用内置enumerrate函数会有更加直接,优美的做法,先看看enumerate的定义: def enumerate(collection): 'Generates an inde

  • python中dir函数用法分析

    本文实例讲述了python中dir函数用法.分享给大家供大家参考.具体分析如下: dir 函数返回任意对象的属性和方法列表, 包括模块对象.函数对象.字符串对象.列表对象.字典对象 ...... 相当多的东西. dir函数示例: >>> li = [] >>> dir(li) ['append','count','extend','index','insert', 'pop','remove','reverse','sort'] >>> d = {}

  • python中sleep函数用法实例分析

    本文实例讲述了python中sleep函数用法.分享给大家供大家参考.具体如下: Python中的sleep用来暂停线程执行,单位为秒 #----------------------------------- # Name: sleep.py # Author: Kevin Harris # Last Modified: 02/13/04 # Description: This Python script demonstrates # how to use the sleep() # funct

随机推荐