定义函数
简单函数实例
def greet():
print('Hello!')
#运行
greet()
Hello!
向函数传递信息
def greet(username):
print('Hello,'+username.title()+'!')
#运行
greet('tom')
Hello,Tom!
其中username是形参,‘tom’是实参
默认值
编写函数时,可给每个形参指定默认值。
如果给username提供了实参,Python将忽略这个形参的默认值
def greet(username='everyone'):
print('Hello,'+username.title()+'!')
#运行
greet()
Hello,Everyone!
返回值 return
字典和列表都可以返回
让实参变成可选的
为让中间名变成可选的,可给实参middle_name指定一个默认值——空字符串,移到形参列表的末尾,并在用户没有提供中间名时不使用这个实参。 为让get_formatted_name()在没有提供中间名时依然可行,可给实参middle_name指定一个默认值——空字符串,并将其移到形参列表的末尾:
def get_formatted_name(first_name, last_name, middle_name=''):
"""返回整洁的姓名"""
if middle_name:
full_name = first_name + ' ' + middle_name + ' ' + last_name
else:
full_name = first_name + ' ' + last_name
return full_name.title()
musician = get_formatted_name('jimi', 'hendrix')
print(musician)
musician = get_formatted_name('john', 'hooker', 'lee')
print(musician)
#结果
Jimi Hendrix
John Lee Hooker
传递任意数量的实参
预先不知道函数需要接受多少个实参,可以用在形参前加*号
def make_pizza(*toppings):
"""打印顾客点的所有配料"""
print(toppings)
make_pizza('pepperoni')
make_pizza('mushrooms', 'green peppers', 'extra cheese')
形参名*toppings中的星号让Python创建一个名为toppings的空元组,并将收到的所有值都封装到这个元组中。
结合使用位置实参和任意数量实参
如果要让函数接受不同类型的实参,必须在函数定义中将接纳任意数量实参的形参放在最后。 Python先匹配位置实参和关键字实参,再将余下的实参都收集到最后一个形参中。
例如,如果前面的函数还需要一个表示比萨尺寸的实参,必须将该形参放在形参*toppings的前面:
def make_pizza(size, *toppings):
"""概述要制作的比萨"""
print("\nMaking a " + str(size) +
"-inch pizza with the following toppings:")
for topping in toppings:
print("- " + topping)
make_pizza(16, 'pepperoni')
make_pizza(12, 'mushrooms', 'green peppers', 'extra cheese')
#结果
Making a 16-inch pizza with the following toppings:
- pepperoni
Making a 12-inch pizza with the following toppings:
- mushrooms
- green peppers
- extra cheese
基于上述函数定义, Python将收到的第一个值存储在形参size中,并将其他的所有值都存储在元组toppings中。在函数调用中,首先指定表示比萨尺寸的实参,然后根据需要指定任意数量的配料。
使用任意数量的关键字实参
有时候,需要接受任意数量的实参,但预先不知道传递给函数的会是什么样的信息。在这种情况下,可将函数编写成能够接受任意数量的键—值对——调用语句提供了多少就接受多少。
main.py
def student(name,id,**put):
troops={}
troops[name]=id
print(put)
for k,v in put.items():
troops[k]=v
return troops
结果:
{'b': 2, 'c': 3, 'd': 4}
{'a': 1, 'b': 2, 'c': 3, 'd': 4}
打**的形参,内容会以字典键-值对的方式存进去
将函数存储在模块中
导入整个模块
要让函数是可导入的,得先创建模块。 模块是扩展名为.py的文件,包含要导入到程序中的代码。
比如新建一个test.py
import main
ic=main.student('a',1,b=2,c=3,d=4)
print(ic)
同样能输出上列的结果
导入特定函数
通过用逗号分隔函数名,可根据需要从模块中导入任意数量的函数:
from module_name import function_0, function_1, function_2
这样的函数不需要指定文件名,可以直接使用
使用as指定别名
- 可以给函数指定
例如:
from main import student as st
这样可以使用st()来替代student()
- 还可以给模块指定
例如:
import main as p
使用*:导入模块中所有函数
from mian import *
- 由于导入了每个函数,可通过名称来调用每个函数,而无需使用句点表示法。然而,使用并非自己编写的大型模块时,最好不要采用这种导入方法:如果模块中有函数的名称与你的项目中使用的名称相同,可能导致意想不到的结果: Python可能遇到多个名称相同的函数或变量,进而覆盖函数,而不是分别导入所有的函数。
- 最佳的做法是,要么只导入你需要使用的函数,要么导入整个模块并使用句点表示法。这能让代码更清晰,更容易阅读和理解。
格式
- 应给函数指定描述性名称,且只在其中使用小写字母和下划线。描述性名称可帮助你和别人明白代码想要做什么。给模块命名时也应遵循上述约定。
- 每个函数都应包含简要地阐述其功能的注释,该注释应紧跟在函数定义后面,并采用文档字符串格式。
- 给形参指定默认值时,等号两边不要有空格,当然调用时也遵守这种规定
#定义时
def function_name(parameter_0, parameter_1='default value')
#调用时
function_name(value_0, parameter_1='value')
- 如果形参很多,导致函数定义的长度超过了79字符,可在函数定义中输入左括号后按回车键,并在下一行按两次Tab键,从而将形参列表和只缩进一层的函数体区分开来
- 如果程序或模块包含多个函数,可使用两个空行将相邻的函数分开,这样将更容易知道前一个函数在什么地方结束,下一个函数从什么地方开始。
- 所有的import语句都应放在文件开头