一、函数

def 函数名(参数):

    ...
函数体
...
返回值

函数的定义主要有如下要点:

  • def:表示函数的关键字
  • 函数名:函数的名称,日后根据函数名调用函数
  • 函数体:函数中进行一系列的逻辑计算,如:发送邮件、计算出 [11,22,38,888,2]中的最大数等...
  • 参数:为函数体提供数据
  • 返回值:当函数执行完毕后,可以给调用者返回数据。

有参数实现

# def test(x):
# '''
# y=2*x+1
# :param x:整形数字
# :return: 返回计算结果
# '''
# y=2*x + 1
# return y
#
# a=test(3)
# print(a)

无参数实现

# def test():
# '''
# y=2*x+1
# :param x:整形数字
# :return: 返回计算结果
# '''
# x=3
# y=2*x + 1
# return y
#
# a=test()
# print(a)

函数的返回值

总结:
返回值数=0:返回None
返回值数=1:返回Object
返回值数>1:返回tuple

函数参数

    # def test(x,y,z): #x=1,y=2,z=3
    # print(x)
    # print(y)
    # print(z)
    # 位置参数,必须一一对应,缺一不行,多一也不行
    # test(1,2,3)
    # 关键字参数,无须一一对应,缺一不行多一也不行
    # test(y=1,x=3,z=2)
    # 混合使用位置参数必须在关键字参数左边
    # test(1,y=2,3) #报错
    # test(1,3,y=2) #报错
    # test(1,3,z=2)
    # test(1,3,z=2,y=4) #报错,y 传入了多个值

默认参数:

    # def handle(x,type='mysql'):
    # print(x)
    # print(type)
    # handle('hello')            #返回:hello mysql
    # # handle('hello',type='sqlite')   #返回:hello sqlite
    # # handle('hello','sqlite')

动态参数:参数组:**字典 *列表

  1)

    # def test(x,*args):
    # print(x)
    # print(args)
    # print(args[0][0])
    # test(1)
    # test(1,2,3,4,5,6)
    # test(1,{'name':'alex'})
    # test(1,['x','y','z']) #把列表当作一个整体传进去
    # test(1,*['x','y','z']) #遍历列表
    # test(1,*('x','y','z')) #遍历元祖
  2)
    # def test(x,**kwargs):
    # print(x)
    # print(kwargs)
    # test(1,y=2,z=3)
    # test(1,y=2,z=3,z=4) #会报错:一个参数不能传两个值,传值重复
  3)
    # def test(x,*args,**kwargs):
    # print(x)
    # print(args,args[-1])
    # print(kwargs,kwargs.get('y'))
    # # test(1,1,2,3,4,5,x=1,y=2,z=3) #报错
    # # test(1,1,2,3,4,5,y=2,z=3)
    # test(1,*[1,2,3],**{'y':1})

二、全局变量与局部变量

代码规范:全局变量变量名都大写,局部变量变量名都小写
     全局变量顶头写
    # 当全局变量与局部变量同名时:
    # 在定义局部变量的子程序内,局部变量起作用;在其它地方全局变量起作用
name = 'lyj'

def change_name():
print('我的名字',name) change_name()

    返回:我的名字 lyj

name = 'lyj'
def change_name():
name='甩了一比'
print('我的名字',name) change_name()
print(name)

    返回:

      我的名字 甩了一比
      lyj

name = 'lyj'
def change_name():
global name #引用全局变量,声明成全局变量了,其他函数的name也变成 甩了一比了
            # global name : global 用于将局部变量声明成全局变量
    name = '甩了一比'
print('我的名字', name) change_name()
print(name)

    返回:

      我的名字 甩了一比
      甩了一比


# 如果函数内部无 global 关键字,优先读取局部变量,只能读取全局变量,无法对全局变量重新赋值 name='adfga',
# 但是对于可变对象,可以对内部元素进行操作,name.append("afgadgs")
# 如果函数内部有 global 关键字,变量本质上就是全局的那个变量,可读取可赋值 name='adgc' # 如果函数内部无 global 关键字,
# - 有声明局部变量
# name = ["Q","W"]
# def fuck():
# name = "R"
# print("fuck",name)
# fuck()
# - 无声明局部变量
# name = ["Q","W"]
# def fuck():
# name.append("T") #列表的方法都可以用
# print("fuck",name)
# fuck()
# 如果函数内部有 global 关键字,
# - 有声明局部变量
# name = ["Q","W"]
# def fuck():
# global name
# name = "R"
# print("fuck",name)
# fuck() # 错误示例:
# name = ["Q","W"]
# def fuck():
# name = "R"
# global name #全局变量声明要往上提
# print("fuck",name)
# fuck()
# - 无声明局部变量
# name = ["Q","W"]
# def fuck():
# global name
# name = "Y"
# name.append("T") #列表的方法都可以用
# print("fuck",name)
# fuck()   

关于 global 和 nonlocal 参考: https://www.cnblogs.com/z360519549/p/5172020.html

三、递归

#递归调用是函数嵌套调用的一种特殊形式,函数在调用时,直接或间接调用了自身,就是递归调用,在使用递归策略时,必须有一个明确的递归结束条件,称为递归出口。

递归的两个阶段:回溯,递推
   回溯就是从外向里一层一层递归调用下去,
回溯阶段必须要有一个明确地结束条件,每进入下一次递归时,问题的规模都应该有所减少(否则,单纯地重复调用自身是毫无意义的) 递推就是从里向外一层一层结束递归
import  time
def calc(n):
print(n)
time.sleep(1)
calc(n) calc(10)

递归例子:

import time

person_list=['alex','wupeiqi','linhaifeng','zsc']
def ask_way(person_list):
print('-'*60)
if len(person_list) == 0:
return '根本没人知道'
person=person_list.pop(0)
if person == 'linhaifeng':
return '%s说:我知道,老男孩就在沙河汇德商厦,下地铁就是' %person print('hi 美男[%s],敢问路在何方' % person)
print('%s回答道:我不知道,但念你慧眼识猪,你等着,我帮你问问%s...' % (person, person_list))
time.sleep(1)
res=ask_way(person_list) print('%s问的结果是: %res' %(person,res))
return res res=ask_way(person_list)
print(res)

返回结果:

D:\Python35\python3.exe D:/python_s3/day15/.py
------------------------------------------------------------
hi 美男[alex],敢问路在何方
alex回答道:我不知道,但念你慧眼识猪,你等着,我帮你问问['wupeiqi', 'linhaifeng', 'zsc']...
------------------------------------------------------------
hi 美男[wupeiqi],敢问路在何方
wupeiqi回答道:我不知道,但念你慧眼识猪,你等着,我帮你问问['linhaifeng', 'zsc']...
------------------------------------------------------------
wupeiqi问的结果是: 'linhaifeng说:我知道,老男孩就在沙河汇德商厦,下地铁就是'es
alex问的结果是: 'linhaifeng说:我知道,老男孩就在沙河汇德商厦,下地铁就是'es
linhaifeng说:我知道,老男孩就在沙河汇德商厦,下地铁就是

(五)、python 函数的更多相关文章

  1. 十五. Python基础(15)--内置函数-1

    十五. Python基础(15)--内置函数-1 1 ● eval(), exec(), compile() 执行字符串数据类型的python代码 检测#import os 'import' in c ...

  2. [Python学习笔记][第五章Python函数设计与使用]

    2016/1/29学习内容 第四章 Python函数设计与使用 之前的几页忘记保存了 很伤心 变量作用域 -一个变量已在函数外定义,如果在函数内需要修改这个变量的值,并将这个赋值结果反映到函数之外,可 ...

  3. python学习三十五天函数递归的用法

    python函数递归就是自己调用自己,无限循环,但是python限制了调用的次数1000次,就会终止,递归用在栏目分类,采集程序比较多,下面简单说函数递归用法和实例 1,函数递归用法 def func ...

  4. Python入门笔记(18):Python函数(1):基础部分

    一.什么是函数.方法.过程 推荐阅读:http://www.cnblogs.com/snandy/archive/2011/08/29/2153871.html 一般程序设计语言包含两种基本的抽象:过 ...

  5. 四年级--python函数基础用法

    一.函数的定义,调用和返回值 1.1 语法 def 函数(参数一,参数二...): ''' 文档注释 ''' 代码逻辑一 代码逻辑二 .... return 返回值 1.2 定义函数的三种形式 说明: ...

  6. Python函数的定义、参数传入与函数的调用

    作为计算机代码的一种抽象方式,函数在Python中扮演了极为重要的角色.今天给大家介绍Python函数的定义.参数的传入以及调用方式.其中函数参数的传入方式为本节重点内容.Python函数的参数形式包 ...

  7. 二十五. Python基础(25)--模块和包

    二十五. Python基础(25)--模块和包 ● 知识框架   ● 模块的属性__name__ # my_module.py   def fun1():     print("Hello& ...

  8. python:函数中五花八门的参数形式(茴香豆的『回』字有四种写法)

    毫不夸张的说,python语言中关于函数参数的使用,是我见过最为灵活的,随便怎么玩都可以,本文以数学乘法为例,演示几种不同的传参形式: 一.默认参数 def multiply1(x, y): retu ...

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

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

  10. 【290】Python 函数

    参考:Python 函数 参考:7.3 给函数参数增加元信息(增加参数的数据类型) 目录: 一.语法 二.说明 三.参数传递 四.参数 4. 1 必备参数 4.2 关键字参数 4.3 缺省参数 4.4 ...

随机推荐

  1. Java集合篇五:HashMap

    1.HasMap 自定义基础版 package com.test.collection; /** * 自定义实现Map功能 * map :存放键值对,根据键对象找对应的值对象 * @author ch ...

  2. sort属性

    学习文章---链接 总结笔记 ①sort是Array.prototype的属性, ②如果不写入参数,则按照转换为的字符串的每个字符的unicode位点进行排序, ③如果传入一个比较函数sort(fun ...

  3. mongodb 32为安装

    启动命令:mongod --dbpath D:\MongoDB\data --logpath c:\MongoDB\log\mongod.log --journal 安装引擎: mongod --db ...

  4. .Net中会存在内存泄漏吗

    所谓内存泄露就是指一个不再被程序使用的对象或变量一直被占据在内存中..Net 中有垃圾回收机制,它可以保证一对象不再被引用的时候,即对象编程了孤儿的时候,对象将自动被垃圾回收器从内存中清除掉.虽然.N ...

  5. day010-缓冲流、转换流、序列化流

    1.     缓冲流 又称为高效流.高效流高效的原理:使用缓冲区(数组)临时存储多个数据,减少底层资源的调用次数.从而提高读写速度. 1.1 缓冲流分类 字节缓冲流: BufferedOutputSt ...

  6. Zookeeper的集群配置和Java测试程序

    Zookeeper是Apache下的项目之一,倾向于对大型应用的协同维护管理工作.IBM则给出了IBM对ZooKeeper的认知: Zookeeper 分布式服务框架是 Apache Hadoop 的 ...

  7. oracle_great_integration_译文

    website:https://www.oracle.com/corporate/features/great-integrations.html Great Integrations(伟大的整合) ...

  8. Scrum第三次冲刺

    1.第三次冲刺任务概述 我们设计的长大万能通系统主要实现以下几个功能: a.周边查询 b.快递代取 c.查看校内新闻动态 d.二手物品交易 第三次冲刺我们计划实现周边查询功能.可以根据评分.距离最近. ...

  9. python25 python的三目运算符

    其他语言的三目运算符大类似: 条件 ?  条件为真返回值: 条件为假返回值 python不一样: 条件为真的返回值  if  条件  else  条件为假的返回值                 或者 ...

  10. 【转】有关onpropertychange事件

    <div style="border:1px solid #fc0;height:24px;width:300px;" id="target">&l ...