标签:实参 cti 应该 代码块 存在 fun 遇到 形参 取值
函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。
函数能提高应用的模块性,和代码的重复利用率。你已经知道Python提供了许多内建函数,比如print()。但你也可以自己创建函数,这被叫做用户自定义函数。
你可以定义一个由自己想要功能的函数,以下是简单的规则:
def functionname( parameters ):
"函数_文档字符串"
function_suite
return [expression]
#!/usr/bin/env python # -*- coding:utf-8 -*- def func(): # 函数定义 print ("hello world") #函数内的语句 func() #函数调用 #运行结果 hello world
形式参数:在定义函数时,定义的参数叫作形参。
实际参数:在函数调用时,传递的参数叫作实参。
#!/usr/bin/env python # -*- coding:utf-8 -*- def func(str): # 函数定义,定义一个形参 print (str) #函数内的语句 func("这是我传递的一个参数") #函数调用 #运行结果 这是我传递的一个参数
1、函数遇到return则不继续执行,直接跳出函数。
2、返回值可传递给调用者。
3、return语句[表达式]退出函数,选择性地向调用方返回一个表达式。不带参数值的return语句返回None
#!/usr/bin/env python # -*- coding:utf-8 -*- def func(a, b): # 函数定义,定义两个形参 return a + b # 返回a+b的值给函数调用者 num = func(1,2) # 函数调用,定义一个变量接受返回值 print num # 运行结果 3
1、关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值。
2、使用关键字参数允许函数调用时参数的顺序与声明时不一致,因为 Python 解释器能够用参数名匹配参数值。
#!/usr/bin/env python # -*- coding:utf-8 -*- def func(a, b): # 函数定义,定义两个个形参 print (a, b) # 函数内的语句 func(b="world",a="hello") # 函数调用 # 运行结果 (‘hello‘, ‘world‘)
1、如果没有为形参传实际参数,则参数使用缺省值。
2、该种情况下,指定默认值的参数一定要写在最后面,不然会报错。
#!/usr/bin/env python # -*- coding:utf-8 -*- def function4(a, b="good"): # 定义b的默认值为good,如果函数调用时没有为b传递参数,则使用默认值 return a + b print function4("你好") print function4("你好", "小明") # 运行结果: 你好good 你好小明
1、函数可接受任意多个参数,函数默认会把所有参数放在一个元组中,每个参数作为元组的一个元素,函数声明时不会命名。
2、加了星号( * )的变量名会存放所有未命名的变量参数。
3、如果存在真正的形式参数,会把传递进来的参数一次传递给已经定义的形式参数,其他的参数被*接收。
#!/usr/bin/env python # -*- coding:utf-8 -*- def function(b, *a): # 可以和普通参数一起声明 print ("这是被传入的第一个参数: %s 这是被传入的其他参数: %s" % (b, a)) return function(1) function(1, 2) function(1, 2, 3, "a", "b", "c") # 运行结果 这是被传入的第一个参数: 1 这是被传入的其他参数: () 这是被传入的第一个参数: 1 这是被传入的其他参数: (2,) 这是被传入的第一个参数: 1 这是被传入的其他参数: (2, 3, ‘a‘, ‘b‘, ‘c‘)
传入的参数必须以key = value的形式传递,可传递任意多个,函数会把传进来的参数放在字典中保存,每个参数作为字典的一组元素。
#!/usr/bin/env python # -*- coding:utf-8 -*- def function(**a): print a, type(a) function(AA="aa", BB="bb") #运行结果 {‘AA‘: ‘aa‘, ‘BB‘: ‘bb‘} <type ‘dict‘>
1、此种情况任何参数都可以传递,但是如果有普通的形参(k),传递的第一个参数一定会给k。
2、此种情况 **b一定要放在最后,*a放在**b之前。
#!/usr/bin/env python # -*- coding:utf-8 -*- def function(k, *a, **b): print k print a, type(a) print b, type(b) return function(1, 2, 3, "a", "b", ("hello", "world"), AA="aa", BB="bb") #运行结果 1 (2, 3, ‘a‘, ‘b‘, (‘hello‘, ‘world‘)) <type ‘tuple‘> {‘AA‘: ‘aa‘, ‘BB‘: ‘bb‘} <type ‘dict‘>
1、局部变量:在函数内声明的变量,函数内部使用。
2、全局变量:在全局下声明的变量,所有人都可以用。
3、建议全局变量全大写,局部变量全小写。
4、默认情况函数可以调用全局变量,不可以修改全局变量。
5、如果函数内要修改全局变量,可用global声明该变量为全局变量,后在修改。
#!/usr/bin/env python # -*- coding:utf-8 -*- def func1(): a = 30 print a a = 10 func1() print a # 运行结果: 30 10 # 以上结果说明默认情况下在函数内部不能对全局变量进行修改。
#!/usr/bin/env python # -*- coding:utf-8 -*- def func1(): global a a = 30 print a a = 10 func1() print a # 运行结果 30 30 # 如果在函数内部修改全局变量,需要在函数内部用global关键字声明该变量为全局变量。
在 python 中,strings, tuples, 和 numbers 是不可更改的对象,而 list,dict 等则是可以修改的对象。
不可变类型:变量赋值 a=5 后再赋值 a=10,这里实际是新生成一个 int 值对象 10,再让 a 指向它,而 5 被丢弃,不是改变a的值,相当于新生成了a。
可变类型:变量赋值 la=[1,2,3,4] 后再赋值 la[2]=5 则是将 list la 的第三个元素值更改,本身la没有动,只是其内部的一部分值被修改了。
python 函数的参数传递:
不可变类型:类似 c++ 的值传递,如 整数、字符串、元组。如fun(a),传递的只是a的值,没有影响a对象本身。比如在 fun(a)内部修改 a 的值,只是修改另一个复制的对象,不会影响 a 本身。
可变类型:类似 c++ 的引用传递,如 列表,字典。如 fun(la),则是将 la 真正的传过去,修改后fun外部的la也会受影响
python 中一切都是对象,严格意义我们不能说值传递还是引用传递,我们应该说传不可变对象和传可变对象。
#!/usr/bin/python # -*- coding: UTF-8 -*- def ChangeInt(a): a = 10 b = 2 ChangeInt(b) print b # 结果是 2 #运行结果 2
实例中有 int 对象 2,指向它的变量是 b,在传递给 ChangeInt 函数时,按传值的方式复制了变量 b,a 和 b 都指向了同一个 Int 对象,在 a=10 时,则新生成一个 int 值对象 10,并让 a 指向它。
#!/usr/bin/python # -*- coding: UTF-8 -*- # 可写函数说明 def changeme(mylist): "修改传入的列表" mylist.append([1, 2, 3, 4]); print "函数内取值: ", mylist return # 调用changeme函数 mylist = [10, 20, 30]; changeme(mylist); print "函数外取值: ", mylist #实例中传入函数的和在末尾添加新内容的对象用的是同一个引用,故输出结果如下: #运行结果 函数内取值: [10, 20, 30, [1, 2, 3, 4]] 函数外取值: [10, 20, 30, [1, 2, 3, 4]]
标签:实参 cti 应该 代码块 存在 fun 遇到 形参 取值
原文地址:http://www.cnblogs.com/ming5218/p/7898652.html