定义函数

  • 函数的定义
  • 函数的分类
  • 函数的创建方法
  • 函数的返回return

函数的定义

  • 将一件事情的步骤封装在一起并得到最终结果
  • 函数名代表了这个函数要做的事情
  • 函数体是实现函数功能的流程
  • 函数可以帮助我们重复使用功能,通过函数名我们可以知道函数的作用

函数的分类

  • 内置函数:print、id、int、max、min、type....等
  • 自定义函数:def 创建函数

函数的创建方法

通过关键字def来创建函数,def的作用是实现python中函数的创建

函数定义过程:

def 函数名(参数列表):
函数体
# coding:utf-8

def say_Hello():
print("Hello Python")

函数的调用

函数名+()小括号执行函数

# coding:utf-8

# 定义函数
def say_Hello():
print("Hello Python") # 执行函数
say_Hello() # 执行结果:Hello Python

函数的返回return

  • return-将函数结果返回的关键字
  • return只能在函数体内使用
  • return支持返回所有的python类型
  • 有返回值的函数可以赋值给一个变量
  • return也有退出函数的作用
# coding:utf-8

def add(a,b):
c=a+b
return c
result=add(1,2)
print(result)
# 输出结果:3

函数的参数

  • 必传参数
  • 默认参数
  • 不确定参数
  • 参数规则

必传参数

  • 函数中定义的参数没有默认值,在调用函数时如果不传入则会报错
  • 在定义函数的时候,参数后边没有等号与默认值
  • 在定义函数的时候,没有默认值且必须在函数执行的时候传递进去的参数,且顺序与参数的顺序相同,就是必传参数
# coding:utf-8

def add(a,b):
c=a+b
return c
result=add(1,2)
print(result)
# 输出结果:3

默认参数

  • 在定义函数的时候,定义的参数含有默认值,通过赋值语句给他是一个默认值
  • 如果默认参数在调用函数的时候传递了新的值,函数将会优先使用后传入的值进行工作
# coding:utf-8

def add(a,b=1):
c=a+b
return c print(add(1))
# 输出结果:2 print(add(1,3))
# 输出结果:4

不确定参数-可变参数

  • 没有固定的参数名和数量(不知道要传的参数名具体是什么)

  • *args代表:将无参数的值合并成元组
  • **kwargs代表:将有参数与默认值的赋值语句合并成字典
# coding:utf-8

def test_args(*args,**kwargs):
print(args,type(args))
print(kwargs,type(kwargs))
test_args(1,2,3,4,5,6,name="zhangsan",age=22,top=175)
# 输出结果:
# (1, 2, 3, 4, 5, 6) <class 'tuple'>
# {'name': 'zhangsan', 'age': 22, 'top': 175} <class 'dict'>
# coding:utf-8

#参数是变量传递时,需要在变量前面加上*和**来区分传递的是元组还是字典,否则一律按元组*args处理
def test_args(*args,**kwargs):
print(args,type(args))
print(kwargs,type(kwargs)) a=('python','java')
b={"name":"zhangsan","age":22,"top":175} test_args(a,b)
# 输出结果:
# (('python', 'java'), {'name': 'zhangsan', 'age': 22, 'top': 175}) <class 'tuple'>
# {} <class 'dict'> test_args(*a,**b)
# 输出结果:
# ('python', 'java') <class 'tuple'>
# {'name': 'zhangsan', 'age': 22, 'top': 175} <class 'dict'>

参数规则

  • 参数的定义从左到右依次是:必传参数、默认参数、可变元组参数、可变字典参数
  • 函数的参数传递非常灵活
  • 必传参数与默认参数的传参多样化
  • 传递的参数与函数定义时的参数顺序不一致时,使用赋值语句的方式传参
# coding:utf-8

def test(a,b=1,*args):
print(a,b,args) s=(1,2)
test(1,2,*s) #1 2 (1, 2) # test(a=1,b=2,*s)
'''
Traceback (most recent call last):
File "D:/WorkSpace/Python_Study/test01.py", line 8, in <module>
test(a=1,b=2,*s)
TypeError: test() got multiple values for argument 'a'
'''
# 报错原因:当我们必选参数、默认参数与可选的元组类型参数在一起的时候,如果需要采取赋值的形式传参,则在定义函数的时候需要将可变的元组参数放在第一位,之后是必传、默认参数;这是一个特例!!!
def test2(*args,a,b=1):
print(a,b,args)
test2(a=1,b=2,*s) #1 2 (1, 2)
# coding:utf-8

def test(a,b=1,**kwargs):
print(a,b,kwargs)
test(1,2,name="zhangsan") # 1 2 {'name': 'zhangsan'}
test(a=1,b=2,name="zhangsan") # 1 2 {'name': 'zhangsan'}
test(name="zhangsan",age=33,b=2,a=1) # 1 2 {'name': 'zhangsan', 'age': 33}

函数的参数类型

  • 参数类型的定义在python3.7之后可用
  • 函数不会对参数类型进行验证,只是看的作用
  • 函数的参数类型具体是什么,还得看方法中对参数的操作
# coding:utf-8

def test(a:int,b:int=3,*args:int,**kwargs:str):
print(a,b,args,kwargs)
test(1,2,3,'4',name='zhangsan') # 1 2 (3, '4') {'name': 'zhangsan'}

全局变量与局部变量

  • 全局变量
  • 局部变量
  • global

全局变量

函数体内对全局变量只能读取,不能修改

# coding:utf-8

name="张三"
age=22
def test():
name="李四"
print(name)
print(age)
test() #李四 22
print(name) #张三

局部变量

局部变量,无法在函数体外使用

# coding:utf-8

def test():
name="李四" print(name) #报错

global

  • 将全局变量可以在函数体内进行修改
  • global只支持str,int,float,tuple,bool,None类型。
  • 对于list,dict不需要global声明即可应用自带方法在函数体内修改。
  • 不建议使用global对全局变量进行修改
# coding:utf-8

name="张三"
age=22
source={"数学":"100","英语":99,"语文":80}
like=["足球","篮球","乒乓球"]
drink=("雪碧","可乐")
eat={"汉堡","薯条"} def test():
global name,age name="zhangsan"
age=18
source["英语"]=60
like[2]="羽毛球"
# drink[0]="百事" 元组不可变,报错
eat.update("鸡翅") test()
print("%s,%s,%s,%s,%s,%s"%(name,age,source,like,drink,eat))
# 输出结果:zhangsan,18,{'数学': '100', '英语': 60, '语文': 80},['足球', '篮球', '羽毛球'],('雪碧', '可乐'),{'薯条', '翅', '汉堡', '鸡'}

递归函数

  • 递归是一种常见的数学和编程概念。它意味着函数调用自身。这样做的好处是可以循环访问数据以达成结果,类似while和for循环
  • 通过return返回def()自身,即可实现递归效果
# coding:utf-8

count=0

def test():
global count
if count<=5:
count +=1
return test()
else:
print("当前计数为:{}".format(count))
test()
# 输出结果为:当前计数为:6

匿名函数

python 使用 lambda 来创建匿名函数。

所谓匿名,意即不再使用 def 语句这样标准的形式定义一个函数。

  • lambda 只是一个表达式,函数体比 def 简单很多。
  • 自带return
  • lambda的主体是一个表达式,而不是一个代码块。仅仅能在lambda表达式中封装有限的逻辑进去。
  • lambda 函数拥有自己的命名空间,且不能访问自己参数列表之外或全局命名空间里的参数。
  • 虽然lambda函数看起来只能写一行,却不等同于C或C++的内联函数,后者的目的是调用小函数时不占用栈内存从而增加运行效率。
# coding:utf-8

f=lambda x,y:x+y
print(f(1,2)) #3 user=[{"name":"zhangsan"},
{"name":"lisi"},
{"name":"wangwu"}] user.sort(key=lambda x:x["name"])
print(user) #[{'name': 'lisi'}, {'name': 'wangwu'}, {'name': 'zhangsan'}]

Python基础入门(5)- 函数的定义与使用的更多相关文章

  1. python基础入门之函数基础

    **python函数**一.def语名 def语名在运行的时候创建一个新的函数对象并且赋值一个变量名 一个def语句可以出现在任一语句可以出现的地方(python中所有的语名都是实时运行的,没有编译这 ...

  2. Python基础入门总结

    Python基础入门教学 基础中的基础 列表.元组(tuple).字典.字符串 变量和引用 函数 python视频教程下载 基础中的基础 解释型语言和编译型语言差距: Python概述 解释器执行原理 ...

  3. [新手必备]Python 基础入门必学知识点笔记

    Python 作为近几年越来越流行的语言,吸引了大量的学员开始学习,为了方便新手小白在学习过程中,更加快捷方便的查漏补缺.根据网上各种乱七八糟的资料以及实验楼的 Python 基础内容整理了一份极度适 ...

  4. python基础——高阶函数

    python基础——高阶函数 高阶函数英文叫Higher-order function.什么是高阶函数?我们以实际代码为例子,一步一步深入概念. 变量可以指向函数 以Python内置的求绝对值的函数a ...

  5. Swift语法基础入门三(函数, 闭包)

    Swift语法基础入门三(函数, 闭包) 函数: 函数是用来完成特定任务的独立的代码块.你给一个函数起一个合适的名字,用来标识函数做什么,并且当函数需要执行的时候,这个名字会被用于“调用”函数 格式: ...

  6. Python基础入门教程

    Python基础入门教程 Python基础教程 Python 简介 Python环境搭建 Python 基础语法 Python 变量类型 Python 运算符 Python 条件语句 Python 循 ...

  7. python基础——内置函数

    python基础--内置函数  一.内置函数(python3.x) 内置参数详解官方文档: https://docs.python.org/3/library/functions.html?highl ...

  8. python学习第五讲,python基础语法之函数语法,与Import导入模块.

    目录 python学习第五讲,python基础语法之函数语法,与Import导入模块. 一丶函数简介 1.函数语法定义 2.函数的调用 3.函数的文档注释 4.函数的参数 5.函数的形参跟实参 6.函 ...

  9. 『Python基础-3』变量、定义变量、变量类型、关键字Python基础-3』变量、定义变量、变量类型、关键字

    『Python基础-3』变量.定义变量.变量类型.关键字 目录: 1.Python变量.变量的命名 2.变量的类型(Python数据类型) 3.Python关键字 1. Python 变量.变量的命名 ...

  10. 自学Python之路-Python基础+模块+面向对象+函数

    自学Python之路-Python基础+模块+面向对象+函数 自学Python之路[第一回]:初识Python    1.1 自学Python1.1-简介    1.2 自学Python1.2-环境的 ...

随机推荐

  1. 18-Spring Cloud Alibaba Nacos

    简介 为什么叫Nacos 前四个字母分别为Naming和Configuration的前两个字母,最后的s为Service Nacos是什么 一个更易于构建云原生应用的动态服务发现.配置管理和服务管理平 ...

  2. Centos8 Docker部署 .Net6 项目

    .Net6项目发布 1.在VS中发布项目,并编写好Dockerfile文件 Dockerfile文件内容如下: FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS ...

  3. Eclipse使用JDBC方式连接SQLServer2008

    JDBC_连接数据库一.配置 (一)  通过SQL Server配置管理器配置相关部分: 右键点击,启动tcp/ip协议右键点击属性查看自己的TCP端口号,记住,后面会用到右键点击SQL Server ...

  4. [luogu7078]贪吃蛇

    结论:若$a_{n}-a_{1}\ge a_{2}$,那么一定会吃掉 证明:分类讨论,若$a_{n-1}$也吃掉了$a_{2}$,就说明$a_{n-1}$之后不会被吃掉,而$a_{n-1}-a_{2} ...

  5. 跟着老猫来搞GO-内建容器Map

    前期回顾 在上面的文章中,老猫和大家分享了GO语言中比较重要的两种数据结构,一种是数组,另外一种是基于数组的slice.本篇文章想要继续和大家分享剩下的容器以及字符字符串的处理. MAP map的定义 ...

  6. [GYCTF2020]Easyphp

    知识点 反序列化pop链 反序列化字符逃逸 解题过程 www.zip 备份文件获取源码 审计代码构造pop链 <?php Class UpdateHelper{ public $id; publ ...

  7. k8s-Pod污点与容忍

    目录 Pod污点与容忍 大白话先解释一下污点与容忍 为什么要用污点和容忍? 官方解释 Taints参数 标记污点 容忍污点 取消所有节点污点 Pod污点与容忍 大白话先解释一下污点与容忍 污点:被打上 ...

  8. SSM(Spring-MyBatis-SpringMVC)框架整合【完整版】

    整合SSM 01 基本配置文件的关系 web.xml配置DispatcherServlet 02 需要的maven依赖 <!--依赖 1.junit 2.数据库连接池 3.servlet 4.j ...

  9. Linux-各种姿势(less\vi等)打开各种类型的文件(txt/csv/xlsx等)出现不能打开(全乱码、部分乱码、二进制文件等)的问题

    (一)linux各种中文乱码解决办法整理 远程登录服务器用vim在终端下编辑查看文件经常会遇见各种中文乱码问题. 做如下设置可基本解决vim中文乱码问题,首先查看系统对中文的支持locale -a | ...

  10. Linux搭建yum仓库

    1.安装nginx 2.为nginx搭建共享目录 3.安装createrepo,创建存储库 4.客户端测试 1.安装nginx yum list |grep nginx #查看是否有可用的nginx包 ...