函数通过def
关键字定义。def关键字后跟一个函数的 标识符 名称,然后跟一对圆括号。圆括号之中可以包括一些变量名,该行以冒号结尾。接下来是一块语句,它们是函数体。
例:
# Filename: function1.py def sayHello(): print 'Hello World!' # block belonging to the function sayHello() # call the function
# Filename: func_param.py def printMax(a, b): if a > b: print a, 'is maximum' else: print b, 'is maximum' printMax(3, 4) # directly give literal values x = 5 y = 7 printMax(x, y) # give variables as arguments
使用局部变量的函数:
# Filename: func_local.py def func(x): print 'x is', x x = 2 print 'Changed local x to', x x = 50 func(x) print 'x is still', x
x is 50 Changed local x to 2 x is still 50
# Filename: func_global.py def func(): global x print 'x is', x x = 2 print 'Changed local x to', x x = 50 func() print 'Value of x is', x
x is 50 Changed global x to 2 Value of x is 2你可以使用同一个
global
语句指定多个全局变量。例如
global x, y, z
。
默认参数值:
对于一些函数,你可能希望它的一些参数是 可选 的,如果用户不想要为这些参数提供值的话,这些参数就使用默认值。这个功能借助于默认参数值完成。你可以在函数定义的形参名后加上赋值运算符(=)和默认值,从而给形参指定默认参数值。注意,默认参数值应该是一个参数。更加准确的说,默认参数值应该是不可变的
# Filename: func_default.py def say(message, times = 1): print message * times say('Hello') say('World', 5)
Hello WorldWorldWorldWorldWorld
def func(a, b=5)
是有效的,但是
def func(a=5, b)
是 无效 的。
使用关键参数:
# Filename: func_key.py def func(a, b=5, c=10): print 'a is', a, 'and b is', b, 'and c is', c func(3, 7) func(25, c=24) func(c=50, a=100)
# Filename: func_return.py def maximum(x, y): if x > y: return x else: return y print maximum(2, 3)
$ python func_return.py 3
maximum
函数返回参数中的最大值,在这里是提供给函数的数。它使用简单的if..else
语句来找出较大的值,然后 返回 那个值。
注意,没有返回值的return
语句等价于return None
。None
是Python中表示没有任何东西的特殊类型。例如,如果一个变量的值为None
,可以表示它没有值。
除非你提供你自己的return
语句,每个函数都在结尾暗含有return None
语句。通过运行print someFunction()
,你可以明白这一点,函数someFunction
没有使用return
语句,如同:
def
someFunction
():
pass
pass
语句在Python中表示一个空的语句块。
# Filename: func_doc.py def printMax(x, y): '''Prints the maximum of two numbers. The two values must be integers.''' x = int(x) # convert to integers, if possible y = int(y) if x > y: print x, 'is maximum' else: print y, 'is maximum' printMax(3, 5) print printMax.__doc__
$ python func_doc.py 5 is maximum Prints the maximum of two numbers. The two values must be integers.
文档字符串的惯例是一个多行字符串,它的首行以大写字母开始,句号结尾。第二行是空行,从第三行开始是详细的描述。 强烈建议 你在你的函数中使用文档字符串时遵循这个惯例。
你可以使用__doc__
(注意双下划线)调用printMax
函数的文档字符串属性(属于函数的名称)。请记住Python把 每一样东西 都作为对象,包括这个函数。我们会在后面的类一章学习更多关于对象的知识。
如果你已经在Python中使用过help()
,那么你已经看到过DocStings的使用了!它所做的只是抓取函数的__doc__
属性,然后整洁地展示给你。你可以对上面这个函数尝试一下——只是在你的程序中包括help(printMax)
。记住按q退出help
。
自动化工具也可以以同样的方式从你的程序中提取文档。因此,我 强烈建议 你对你所写的任何正式函数编写文档字符串。随你的Python发行版附带的pydoc命令,与help()
类似地使用DocStrings。
5 is maximum Help on function printMax in module __main__: printMax(x, y) Prints the maximum of two numbers. The two values must be integers.