Python的四类函数:

  1.普通函数

  2.默认函数

  3.关键字函数

  4.收集参数

1.普通函数

a.定义的时候直接定义变量名

b.调用的时候直接把变量或者值放入指定位置

      

      def 函数名(参数1,参数2...):
        函数体

      # 调用

      函数名(value1,value2....)  

      # 调用的时候,具体值参考的是位置,按位置赋值

# 参数的定义和使用
# 参数person,只是一个符号,代表的事调用的时候的某一个数据
# 调用的时候,会用p的值代替函数中所有的person
def hello(person):
print("{0},你好".format(person))
print("吃饭呀!") p = "many"
hello(p)

2.默认函数

a.形参带有默认值

b.调用的时候,如果没有对应的形参传值,则使用默认值

      der func_name(p1=v1,p2=v2....)
      func_block

      # 调用
      func_name()

      # 调用2
      value=1
      value=2
      func_name(value1,value2....)

  

# 默认参数示例
# 报名小例子,需要知道学生的性别
# 思路:
# 学习程序员的一般来说都是男生,所以,报名的时候如果没有特别的指定,认为是男生 def baoming(name,age,sex="male"):
if sex == "male":
print("{0},今年{1}岁,他很棒!".format(name,age))
else:
print("{0},今年{1}岁,ta很棒!".format(name,age)) baoming("张三",18)
baoming("小红",18,“"female")

3.关键字参数

a.语法

    def func(p1=v1,p2=v2....)
    func_body

    调用函数:
    func(p1=v1,p2=v2.....)

b.比较麻烦,但是也有好处

  1.不容易混淆,一般实参和形参只是按位置一一对应即可,容易出错

  2.使用关键字参数,可以不用考虑参数的位置

# 关键字参数使用示例1:
def stu(name,age,addr):
print("i an student")
print("我叫{0},我叫{1},我住{2}".format(name,age,addr)) n = "张三"
a = ""
addr = "上海" # 普通参数,只能按照位置传递,容易出错
stu(n,a,addr)
# 关键字参数使用示例2:
def stu(name = "none",age = 0,addr = "none"):
print("i an student")
print("我叫{0},我叫{1},我住{2}".format(name,age,addr)) n = "张三"
a = ""
addr = "上海" # 这样就是一一对应的关系
stu(name = n, age = a, addr =addr)

4.收集参数

a.把没有位置,不能和定义时的参数位置相对应参数,放入一个特定的数据结构中

b.语法

    

    def func(*args):
    func_body
    按照list使用方式访问args得到传入的参数

    调用:
    func(p1,p2,p3...)

  b-1:参数名args不是必须这么写,但是,我们推荐直接使用args,约定俗成

  b-2:参数名args钱需要有星号

  b-3:收集参数可以和其他参数共存

# 收集参数代码
# 函数模拟一个学生进行一个自我介绍,但是内容具体不清楚
# args把他看做一个list
def stu( *args):
print("大家好,我为大家简单自我介绍以下:")
# type 函数作用是检测变量的类型
print(type(args))
#需要进行遍历
for item in args:
print(item, end=" ")
print() stu("zhangsan", 18, "beijing")
stu("lishi")

大家好,我为大家简单自我介绍以下:

<class 'tuple'>
zhangsan 18 beijing
大家好,我为大家简单自我介绍以下:
<class 'tuple'>
lishi >>>对于tuple的遍历,在python中遍历一般都是用for遍历

收集函数也能为空

# 收集参数实例
# 说明收集参数可以不带任何实参调用,此时收集参数为空tuple
# tuple和list是兄弟俩个
stu()
# 如果使用关键字参数格式调用,会出现问题
stu(name="zhangsan")

报错:

---------------------------------------------------------------------------
TypeError Traceback (most recent call last)
<ipython-input-15-8a4d15627038> in <module>()
1 # 如果使用关键字参数格式调用,会出现问题
----> 2 stu(name="zhangsan") TypeError: stu() got an unexpected keyword argument 'name'

此处在收集函数中不能使用关键字蚕食调用,但是在字典中可以使用关键字参数调用

4-1:收集参数之关键字收集参数

语法:

    def func( **kwargs):
    func_body

    调用:
    func(p1=v1, p2=v2, p3=v3....)

- kwargs一般约定俗成
- 调用的时候,把多余的关键字参数放入kwagrs
- 访问kwargs需要按字典格式访问

# 收集参数案例
# 自我介绍
# 调用的时候需要使用关键字参数调用
def stu( **kwargs):
# 在函数体内对于kwargs的使用不用带星号
print("大家好,我为大家简单自我介绍以下:")
print(type(kwargs))
# 对于字典的访问,python2和python3 有区别
# 对于字典的访问kwargs.items()
for k,v in kwargs.items():
print(k, "---", v) stu(name="zhangsan", age=18, addr="bejing")
stu(name="lishi")
大家好,我为大家简单自我介绍以下:
<class 'dict'>
name --- zhangsan
age --- 18
addr --- bejing
大家好,我为大家简单自我介绍以下:
<class 'dict'>
name --- lishi 此处收集参数也可以为空

4-2:收集参数混合调用的顺序问题

- 收集函数,关键字函数,普通函数可以混合使用
- 使用规则就是,普通参数和关键字参数有限
- 定义的时候一般先找普通参数,关键字参数,收集参数,收集参数tuple,收集参数dict

# 收集参数混合调用案例
# stu模拟一个学生的自我介绍
def stu(name, age, hobby="没有",*args, **kwargs):
print("hello 大家好")
print("我叫{0},我今年{1}岁了!".format(name,age))
if hobby == "没有":
print("很遗憾,我没有爱好")
else:
print("我的爱好是{0}".format(hobby)) print("*"*20) for i in args:
print(i,end=" ")
print("*"*20) for k,v in kwargs.items():
print(k,"---",v) # 开始调用函数
name = "zhangsan"
age = 18
# 调用的不同的格式
stu(name, age) stu(name, age, hobby="python") stu(name, age, hobby="python", hobby2="lklkd",hobby3="听音乐")
hello 大家好
我叫zhangsan,我今年18岁了!
很遗憾,我没有爱好
********************
********************
hello 大家好
我叫zhangsan,我今年18岁了!
我的爱好是python
********************
********************
hello 大家好
我叫zhangsan,我今年18岁了!
我的爱好是python
********************
********************
hobby2 --- lklkd
hobby3 --- 听音乐 返回值:

    - 函数和过程的区别
      - 有无返回值
    - 需要用return显示返回内容
    - 如果没有返回,则默认返回None
    - 推荐写法,无论有无返回值,最后都要以return结束

# 返回值示例
def func_1():
print("有返回值")
return 1
def func_2():
print("没有返回值") f1 = func_1()
print(f1) f2 = func_2()
print(f2)

有返回值
1
没有返回值
None

函数文档:

- 函数的文档的作用是对当前函数提供使用相关的参考信息
- 文档写法:
    - 在函数内部开始的第一行使用三引号字符定义符
    - 一般具有特定格式
    - 参考案例
- 文档查看
    - 使用help函数,形如help(func)
    - 使用——doc——,参考案例(此处为下滑线俩个)

注意:

函数文档的编写在pycharm中有详细的格式要求,在此我就不在阐述了,有兴趣的可以看一下

# 文档案例
# 函数stu是模拟一个学生的自我介绍的内容
def func():
'''
1
2
'''
print("文档案例")
# 查看文档
help(func)
func.__doc__

程序完整代码地址:https://github.com/Zhi-peng-wang

python的四大函数讲解的更多相关文章

  1. Python中高阶函数讲解

    高阶函数讲解 1. 常规高阶函数 递归函数 格式:def func_name(variable): '''__doc__'''#函数的说明文档 if 条件表达式:#限制递归退出值 pass retur ...

  2. python中join()函数讲解

    本文简述的是string.join(words[, sep]),它的功能是把字符串或者列表,元组等的元素给连接起来,返回一个字符串,和split()函数与正好相反,看下面的代码理解. a=[" ...

  3. python中split()函数讲解

    本文讲述的是string.split(s[, sep[, maxsplit]]),针对string类型的split()函数.它主要是切割字符串,结果返回由字符串元素组成的一个列表,具体怎么使用看下面的 ...

  4. Python时间日期函数讲解

    所有日期.时间的api都在datetime模块内. 1. 日期输出格式化 datetime => string import datetime now = datetime.datetime.n ...

  5. python ---split()函数讲解

    python ---split()函数讲解 split中文翻译为分裂. 在python用于分割字符串使用. split()就是将一个字符串分裂成多个字符串组成的列表. split()可以传入参数,也可 ...

  6. Python中利用函数装饰器实现备忘功能

    Python中利用函数装饰器实现备忘功能 这篇文章主要介绍了Python中利用函数装饰器实现备忘功能,同时还降到了利用装饰器来检查函数的递归.确保参数传递的正确,需要的朋友可以参考下   " ...

  7. ViewPager 详解(二)---详解四大函数

    前言:上篇中我们讲解了如何快速实现了一个滑动页面,但问题在于,PageAdapter必须要重写的四个函数,它们都各有什么意义,在上节的函数内部为什么要这么实现,下面我们就结合Android的API说明 ...

  8. Python应用——自定义函数:分割PDF文件函数

    案例 将一个 pdf 文件按要求分割为几个部分.比如说一个pdf有20页,分成5个pdf文件,每个pdf文件包含4页.设计函数实现? Python代码 from PyPDF2 import PdfFi ...

  9. python内置函数和魔法函数

    内置方法:Python中声明每一个类系统都会加上一些默认内置方法,提供给系统调用该类的对象时使用.比如需要实例化一个对象时,需要调用该类的init方法:使用print去打印一个类时,其实调用的是str ...

随机推荐

  1. 我知道的nginx配置

    1.nginx配置文件 2.配置访问域名 #京淘商品管理系统 server { listen 80; server_name manage.jt.com; location / { proxy_pas ...

  2. 错误:无效参数:could not find capabilities for arch=aarch64

    现象:错误:无效参数:could not find capabilities for arch=aarch64 解决: qemu源码编译:(需要指定--cpu=aarch64) ./configure ...

  3. Hibernate入门1 - Hibernate概述及第一个小例子

    一.什么是ORM? ORM,即Object Relational Mapping.我们知道,利用面向对象的思想编写的数据库应用程序最终都是把对象信息保存在关系型数据库中,于是需要编写与底层数据库相关的 ...

  4. setAttribute的浏览器兼容性(转)

    1.element要用getElementById or ByTagName来得到, 2.setAttribute("class", vName)中class是指改变"c ...

  5. [CocoaPods]入门

    什么是CocoaPods? CocoaPods管理Xcode项目的库依赖项. 项目的依赖项在名为Podfile的单个文本文件中指定.CocoaPods将解析库之间的依赖关系,获取生成的源代码,然后在X ...

  6. Spark基础脚本入门实践1

    1.创建数据框架 Creating DataFrames val df = spark.read.json("file:///usr/local/spark/examples/src/mai ...

  7. Liferay的一些应用领域

    Liferay的用途是快速的部署内外站点,统一权限管理,开发Web热插拔插件,并不是所有系统都适合 不适合Liferay的一些应用领域: 1.独立认证.简单的系统,比如一些简单的增删改查:2.复杂业务 ...

  8. Selenium3 + Python3自动化测试系列一——安装Python+selenium及selenium3 浏览器驱动

    一.安装Python https://www.python.org/downloads/ 验证Python是否安装成功.打开Windows命令提示符(cmd),输入python,回车 注意:在安装的过 ...

  9. 自己动手实现爬虫scrapy框架思路汇总

    这里先简要温习下爬虫实际操作: cd ~/Desktop/spider scrapy startproject lastspider # 创建爬虫工程 cd lastspider/ # 进入工程 sc ...

  10. JavaScript中的 this全面解析

    上一章我们排除了一些对this的错误认识和知道了this是在调用函数时被绑定的,完全取决于函数的调用位置.先介绍两个概念:调用位置和调用栈. 调用栈:就是为了到达当前执行位置所调用的所有函数. 调用位 ...