函数是什么

它相当于一个独立的代码块,可以被重复使用,如果需要增加一个功能或者修改一个功能,只需要,增加或者修改函数即可。

函数分类

内置函数

python解释器已经为我们定义好的参数,比如:len(),sum(),max()等

自定义函数

根据自身的需求,自己定制的函数

定义函数

语法

def 函数名(参数1,参数2,参数3,...):
'''注释'''
函数体
return 返回的值

一旦执行到return,整个函数就结束了。如果没有return,会默认返回None。return可以返回多个参数,这多个参数用元组封装。

定义函数的三种形式

#1、无参:应用场景仅仅只是执行一些操作,比如与用户交互,打印
#2、有参:需要根据外部传进来的参数,才能执行相应的逻辑,比如统计长度,求最大值最小值
#3、空函数:设计代码结构, 函数需要函数体,如果没有的话,会报错,这个时候可以写一个pass,这个就表示什么都不做。虽然看起来做的是一件没有用的事情,但是这样可以让程序运行起来。

有参、无参如下:

#定义阶段
def tell_tag(tag,n): #有参数
print(tag*n) def tell_msg(): #无参数
print('hello world') #调用阶段
tell_tag('*',12)
tell_msg()
tell_tag('*',12) '''
************
hello world
************
''' #结论:
#1、定义时无参,意味着调用时也无需传入参数
#2、定义时有参,意味着调用时则必须传入参数 无参、有参

无参如下:

def auth(user,password):
'''
auth function
:param user: 用户名
:param password: 密码
:return: 认证结果
'''
pass def get(filename):
'''
:param filename:
:return:
'''
pass def put(filename):
'''
:param filename:
:return:
'''
def ls(dirname):
'''
:param dirname:
:return:
'''
pass #程序的体系结构立见 空函数

定义阶段做的事情

只检查语法,不执行代码。也就是说:语法错误可以在函数定义的时候检测出来,而代码的逻辑错误只有在执行时才暴露。

如果函数名相同,后面定义的函数会覆盖前面的函数。

使用函数

使用的原则

函数使用的时候,要保证先定义,后调用

例子如下:

函数即“变量”,“变量”必须先定义后引用。未定义而直接引用函数,就相当于在引用一个不存在的变量名
#测试一
def foo():
print('from foo')
bar()
foo() #报错 #测试二
def bar():
print('from bar')
def foo():
print('from foo')
bar()
foo() #正常 #测试三
def foo():
print('from foo')
bar() def bar():
print('from bar')
foo() #会报错吗? #结论:函数的使用,必须遵循原则:先定义,后调用
#我们在使用函数时,一定要明确地区分定义阶段和调用阶段 #定义阶段
def foo():
print('from foo')
bar()
def bar():
print('from bar')
#调用阶段
foo()

调用函数方式

1 语句形式:foo()
2 表达式形式:3*len('hello')
3 当中另外一个函数的参数:range(len('hello'))

函数嵌套

函数嵌套调用

def max(x,y):
return x if x > y else y def max4(a,b,c,d):
res1=max(a,b)
res2=max(res1,c)
res3=max(res2,d)
return res3
print(max4(1,2,3,4))

函数嵌套定义

def f1():
def f2():
def f3():
print('from f3')
f3()
f2() f1()

函数特性

函数是第一类对象,即函数可以当作数据传递

比如:

# 可以被引用
# 可以当作参数传递
# 返回值可以是函数
# 可以当作容器类型的元素

例1:

def demo():
print("demo1")
a = demo
b = a
b()

例2:

def foo():
print('foo') def bar():
print('bar') dic={
'foo':foo,
'bar':bar,
}
while True:
choice=input('>>: ').strip()
if choice in dic:
dic[choice]()

形参和实参

形参即变量名,实参即变量值,函数调用时,将值绑定到变量名上,函数调用结束,解除绑定

具体使用:

#1、位置参数:按照从左到右的顺序定义的参数
位置形参:必选参数
位置实参:按照位置给形参传值 #2、关键字参数:按照key=value的形式定义的实参
无需按照位置为形参传值
注意的问题:
1. 关键字实参必须在位置实参右面
2. 对同一个形参不能重复传值 #3、默认参数:形参在定义时就已经为其赋值
可以传值也可以不传值,经常需要变得参数定义成位置形参,变化较小的参数定义成默认参数(形参)
注意的问题:
1. 只在定义时赋值一次
2. 默认参数的定义应该在位置形参右面
3. 默认参数通常应该定义成不可变类型 #4、可变长参数:
可变长指的是实参值的个数不固定
而实参有按位置和按关键字两种形式定义,针对这两种形式的可变长,形参对应有两种解决方案来完整地存放它们,分别是*args,**kwargs ===========*args=========== def foo(x, y, *args):
print(x, y) # 1 2
print(args) # (3, 4, 5) foo(1, 2, 3, 4, 5) -----------------------------------------------
def foo(x, y, *args):
print(x, y) # 1 2
print(args) # (3, 4, 5) foo(1, 2, *[3, 4, 5])
-----------------------------------------------
def foo(x, y, z):
print(x, y, z) # 1 2 3 foo(*[1, 2, 3]) -----------------------------------------------
def foo(*args, x, y):
print(x, y)
print(args) foo(1, 2, *[3, 4, 5]) # 报错 ===========**kwargs=========== def foo(x, y, **kwargs):
print(x, y) # 1 2
print(kwargs) # {'c': 3, 'a': 1, 'b': 2} foo(1, y=2, a=1, b=2, c=3) ----------------------------------------------
def foo(x, y, **kwargs):
print(x, y) # 1 2
print(kwargs) # {'c': 3, 'a': 1, 'b': 2} foo(1, y=2, **{'a': 1, 'b': 2, 'c': 3})
-----------------------------------------------
def foo(x, y, z):
print(x, y, z) # 2 3 1 foo(**{'z': 1, 'x': 2, 'y': 3}) ===========*args+**kwargs=========== def foo(x, y, *args, **kwargs):
print(x, y) # 1 2
print(args) # (3, 4, 5)
print(kwargs) # {'c': 4, 'b': 3, 'd': 5} foo(1, 2, 3, 4, 5, b=3, c=4, d=5) ----------------------------------------------
*后定义的参数,必须被传值(有默认值的除外),且必须按照关键字实参的形式传递
def foo(x, y, *args, a=1, b, **kwargs):
print(x, y) # 1 2
print(args) # (3, 4, 5)
print(a) #
print(b) #
print(kwargs) # {'c': 4, 'd': 5} foo(1, 2, 3, 4, 5, b=3, c=4, d=5)

函数作用域

函数相当于一个封装好的盒子,里面可以定义局部变量,随着函数的调用和结束,其中的局部变量也随之建立和消亡。而且局部变量只能在该函数中有效。

上面说到过,函数可以嵌套使用,当一个函数内使用一个变量的时候,查找的原则是就近原则。也就是本函数有就使用本函数的,再到上级函数找,找到全局变量之后没有,再发现内置变量也没有的话就会报错。

例1:

max=1
def f1():
max=2
def f2():
max=3
print(max) #
f2()
f1()
print(max) # # 其中max=1属于全局变量,max=2和max3属于局部变量

当使用全局变量的时候,如果全局变量是可变类型的话,可以对其元素进行修改,如果是不可变类型则只能进行取值。

例如:

a = [1, 2, 4, ""]
def demo():
a[3] = 5
print(a) # [1, 2, 4, 5]
demo()
print(a) # [1, 2, 4, 5]

global

当你要使用全局变量的时候可以用global。使用global声明后,可以对全局变量进行修改

例如:

max=1
def f1():
max=2
def f2():
global max
max = 9
print(max) #
f2()
f1()
print(max) #

当你先定义了局部变量再用global声明全局变量的时候就会报错

例如:

max=1
def f1():
max=2
def f2():
max = 3
global max # 报错
max = 9
print(max)
f2()
f1()
print(max)

在实际开发中其实不会产生这种问题,因为根据命名规范,全局变量要大写表示。

注:global可以直接找到全局变量,可以用nonlocal找到上级的变量,这个和global差不多,只不过它找的是上一级函数的

Python——函数基础的更多相关文章

  1. 《转》Python学习(17)-python函数基础部分

    http://www.cnblogs.com/BeginMan/p/3171977.html 一.什么是函数.方法.过程 推荐阅读:http://www.cnblogs.com/snandy/arch ...

  2. Python 函数基础、有序集合、文件操作(三)

    一.set 特点: set是一个无序且不重复的元素集合访问速度快:天生解决元素重复问题 方法: 初始化 >>> s1 = set()>>> print(type(s ...

  3. python函数基础学习

    函数的定义与调用: def 函数名(参数1,参数2): ‘’’函数注释’’’ print(‘函数体’) return 返回值 定  义:def关键字开关,空格之后接函数名和圆括号,最后冒号结尾 def ...

  4. 10分钟学会Python函数基础知识

    看完本文大概需要8分钟,看完后,仔细看下代码,认真回一下,函数基本知识就OK了.最好还是把代码敲一下. 一.函数基础 简单地说,一个函数就是一组Python语句的组合,它们可以在程序中运行一次或多次运 ...

  5. Python函数基础和函数参数

    函数的定义和函数的调用 return的作用 三种参数的定义 常用的内置函数 len() 函数基础 函数的定义 def 函数名(参数): pass return 表达式 pass在这里表示什么都没有,不 ...

  6. python函数基础

    一.基础 函数的定义 def 函数名(参数): ... 函数体 ... 返回值 #如果函数执行完毕也没有return语句时,自动return None. 空函数 如果想定义一个什么事也不做的空函数,可 ...

  7. python 函数基础介绍

    函数是对程序逻辑进行结构化或过程化的一种编程方法.能将整块代码巧妙地隔离成易于管理的小块,把重复代码放在函数中而不是进行大量的拷贝. 一.函数创建 def 函数创建格式如下: def function ...

  8. Python函数基础学习(定义、函数参数、递归函数)

    1.本程序是测试函数的基础.函数的参数.递归函数的测试. 函数的参数有: 必选参数.默认参数.可变参数.命名关键字参数和关键字参数 #!/usr/bin/python # -*- coding: ut ...

  9. python函数基础 与文件操作

    函数的定义 函数是通过赋值传递的,参数通过赋值传递给函数.def语句将创建一个函数对象并将其赋值给一个变量名,def语句的一般格式如下: def function_name(arg1,arg2[,.. ...

  10. 4.python函数基础

    一.函数 1.函数简介 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但 ...

随机推荐

  1. Unity 5着色器系统代码介绍(上)

    http://forum.china.unity3d.com/thread-25724-1-10.html Unity 5着色器系统代码介绍(上) Unity在着色器开发方面提供了很大的灵活性.有些工 ...

  2. 4.高级数据过滤 ---SQL

    一.AND操作符 要通过不止一个列进行过滤,可以使用A ND操作符给WHERE子句附加条件. SELECT prod_id, prod_price, prod_name FROM Products ; ...

  3. 2.排序检索数据 ---SQL

    order by 一.排序数据 SELECT prod_name FROM Products ORDER BY prod_name; ORDER BY子句的位置 在指定一条ORDER BY子句时,应该 ...

  4. python所有的魔术方法

    据说,Python 的对象天生拥有一些神奇的方法,它们总被双下划线所包围,他们是面向对象的 Python 的一切. 他们是可以给你的类增加魔力的特殊方法,如果你的对象实现(重载)了这些方法中的某一个, ...

  5. Ionic中基于js的扩展(指令和服务)来实现各种效果

    1.ion-header-bar ion-footer-bar ion-content align-title='left/ritght/center <body> <ion-hea ...

  6. How far away(DFS+vector存图)

    There are n houses in the village and some bidirectional roads connecting them. Every day peole alwa ...

  7. Avito Cool Challenge 2018-B. Farewell Party(思维)

    time limit per test 1 second memory limit per test 256 megabytes input standard input output standar ...

  8. 如何使用在Windows 下AspNetCore Api 和 consul

    在Windows 下如何使用 AspNetCore Api 和 consul https://blog.csdn.net/sD7O95O/article/details/80750803 一.概念:什 ...

  9. 健康检查NET Core之跨平台的实时性能监控

    ASP.NET Core之跨平台的实时性能监控(2.健康检查)   前言 上篇我们讲了如何使用App Metrics 做一个简单的APM监控,最后提到过健康检查这个东西. 这篇主要就是讲解健康检查的内 ...

  10. 《java学习三》jvm性能优化------jconsul

    利用jconsul检测线程死锁,    死锁的线程,会有   已锁定    三个字 visualVm                       也在jdk里 VisualVM 是一款免费的,集成了多 ...