Python从入门到精通之Seventh!
函数浅析:可以减少代码重用,保持一致性,可扩展性,易维护性。
定义方法:def 函数名(形参):
'''功能注释'''
代码块
打印函数名时,会出现函数的内存地址。两个函数名相同时,最后一个会覆盖之前的所有函数。
过程:没有返回值的函数就是过程,默认返回None。
总结:
返回值数=0,返回None
返回值数=1,返回object
返回值数>1,返回tuple
函数一旦运行至return,则整个函数结束。函数参数必须一 一对应,否则报错。
def test(x,y,z):
print(x)
print(y)
print(z)
#位置参数,必须一 一对应
test(1,2,3)
#关键字参数,无需一 一对应
test(y=2,x=1,z=3)
#位置参数必须在关键字参数左侧,并且一 一对应
test(1,2,z=3)
#参数可无,令其为None
def handle(x,type=None):
print(x)
print(type)
#默认参数,可以修改。
def handle(x,type="mysql"):
print(x)
print(type)
handle('hello','sqlite')
参数组:** 字典 、 * 列表
#参数组,**代表 字典 *代表 列表
#列表形式传值
def test(x,*args)
print(x)
print(args)
test(1,2,3,4,5)
=====》1
(2,3,4,5) test(1,{'name','alex'})
=====》1
({'name','alex'})
#加上*,会依次传给args,若是*后是字典,则会以列表形式遍历keys。
test(1,*['x','y','z'])
=====》1
('x','y','z')
#字典形式传值
def test(x,**kwargs)
print(x)
print(kwargs)
test(1,y=2,z=3)
====》1
{'y':2,"z":3}
*args不可放在**kwargs后面,但是可以放到**kwargs前面。
def test(x,*args,**kwargs):
print(x)
print(args,args[-1])
pirnt(kwargs,kwargs.get('y')) test(1,*[1,2,3],**{'y':1}) ====>1
(1,2,3) 3
{'y':1} 1
全局变量与局部变量
当变量前加一个 global时,局部变量会变成全局变量。
name = 'alex' def change_name():
global name #定义全局
name = 'haha'
print('change your name,'name)
def as_df():
print('as_df',name)
=======>change your name haha
as_df haha
如果局部变量在global上方,则会报错。
def hu():
name = 'hangtian'
print(name)
def xu():
name = '刘禅'
print(name)
def tian():
name = 'sky'
print(name)
print(name)
tian()
xu()
print(name) hu()
=========>>
hangtian
刘禅
刘禅
sky
hangtian
nonlocal指的是上一级变量
#nonlocal,指定上一级变量
name = "gangniang" def weihou():
name = 'hh'
def weiweihou(): #外部的不能拿到内部的
nonlocal name
name = '冷静'
weiweihou()
print(name) print(name)
weihou()
print(name)
==========>>
gangnian
冷静
gangnian
前向引用,风湿理论:函数即变量
name = 'gangnian' def weihou():
name = 'hh'
def weiweihou(): #外部的不能拿到内部的
nonlocal name #拿到上一级的变量
name = '冷静' #对上一级变量进行修改
weiweihou()
print(name) print(name)
weihou()
print(name) #会报错,根据风湿理论分析:函数即变量
def a():
print(1234)
bar()
a()
def bar():
print(123)
递归:
递归特性:
1.必须有一个明确的结束条件
2.每次进入更深一层递归时,问题规模相比上次递归都应有所减少
3.递归效率不高,递归次数过多会导致栈溢出(在计算机中,函数调用是通过栈(stake)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出。
import time person_list=['alex','haha','sky','XT']
def ask_way(person_list): if len(person_list)==0:
return "根本没有人知道路"
person = person_list.pop(0) if person == 'XT':
return "%s说:我知道,向前走,之后左拐,就会看到出口" %person
print('h i,帅哥[%s],敢问路在何方' %person)
print('%s回答道:我不知道,但念及你慧眼识珠,你等着,我给你问问%s' %(person,person_list[0]))
time.sleep(4)
res = ask_way(person_list)
return res res = ask_way(person_list)
print(res) ====================
h i,帅哥[alex],敢问路在何方
alex回答道:我不知道,但念及你慧眼识珠,你等着,我给你问问haha
h i,帅哥[haha],敢问路在何方
haha回答道:我不知道,但念及你慧眼识珠,你等着,我给你问问sky
h i,帅哥[sky],敢问路在何方
sky回答道:我不知道,但念及你慧眼识珠,你等着,我给你问问XT
XT说:我知道,向前走,之后左拐,就会看到出口
Python从入门到精通之Seventh!的更多相关文章
- python从入门到精通之30天快速学python视频教程
点击了解更多Python课程>>> python从入门到精通之30天快速学python视频教程 课程目录: python入门教程-1-Python编程语言历史及特性.mkv pyth ...
- Python从入门到精通之eighth!
函数式编程与内置函数 函数作用域: def test1(): print('in the test1') def test(): print('in the test') return test1() ...
- Python从入门到精通之Sixth!
补充:enumerate 函数用于遍历序列(元组tuple.列表list.字典dict)中的元素以及它们的下标: >>> for i,j in enumerate(('a','b', ...
- Python从入门到精通之Forth!
Python基本数据类型之列表 补充:range()方法 python2: range 立即创建 xrange for循环的时候才一个一个创建 Python3: range for循环的 ...
- Python从入门到精通之Third!
Python运算符 算数运算符:+ - * / % // ** 比较运算符:== > < >= 大于等于 & ...
- Python从入门到精通之Second!
初识Python基础! -基础 -扩展名可以是任意的,但是导入模块时,如果不是.py文件就会报错. -两种执行方式 1.python解释器 文件名.py 文件路径 -Li ...
- Python从入门到精通之First!
Python的种类 Cpython Python的官方版本,使用C语言实现,使用最为广泛,CPython实现会将源文件(py文件)转换成字节码文件(pyc文件),然后运行在Python虚拟机上. Jy ...
- Python从入门到精通之环境搭建
本章内容: Windows系统环境搭建 Linux系统环境搭建 Mac OS系统环境搭建 一.下载python安装包 下载地址:https://www.python.org/downloads/ 二. ...
- Python从入门到精通之Fifth!
字典 类名:dict 字典是无序的. 字典的创建 info = {"k1":{1:"abc",[1,2,3]},"k2":True} ...
随机推荐
- (ZT)算法杂货铺——分类算法之朴素贝叶斯分类(Naive Bayesian classification)
https://www.cnblogs.com/leoo2sk/archive/2010/09/17/naive-bayesian-classifier.html 0.写在前面的话 我个人一直很喜欢算 ...
- DOM访问和处理HTML文档的标准方法
innerHTML获取或替换HTML元素的内容 <p id="d">对于错我无法来判断 </p><script type="text/jav ...
- docker原理(转)
可能是把Docker的概念讲的最清楚的一篇文章 [编者的话]本文只是对Docker的概念做了较为详细的介绍,并不涉及一些像Docker环境的安装以及Docker的一些常见操作和命令. Docker是世 ...
- python day10 函数(第二篇)
2019.4.10 S21 day10笔记总结 一.内容回顾 1.面试题相关: 1.py2和py3的区别 2.运算符的计算 :3 or 9 and 8 3.字符串的反转 4.is和==的区别 5.v1 ...
- springMVC设计模式和javaWeb三层框架
一.springMVC 设计模式 MVC模式是软件工程中的一种能够软件架构模式,把软件分为三个基本部分,模型(model).视图(view)和控制器(controller).使程序简化,更加直观. ...
- step_by_step_xUnit_Net_ABP
这段日子的开发一直使用Asp.net Boilerplate ,称之为项目模板自然就有开发中常用的功能,测试框架也在其中,土牛的ABP源代码都有通过测试,很遗憾的是我之前没有写过测试,不会就要去找资料 ...
- git pre-push hook
This article introduces git pre-push hook. Problem In Lean project, we use a modified version of Goo ...
- 29. Divide Two Integers (JAVA)
Given two integers dividend and divisor, divide two integers without using multiplication, division ...
- 缓存cache介绍
1. 为何要用缓存.缓存的目的是为了什么?(https://my.oschina.net/u/3378039/blog/2986697) 一个程序的瓶颈在于数据库,内存的速度远远大于硬盘的速度,当我 ...
- HBase、MongoDB、cassandra比较
前言 传统数据库遇到的问题,数据量很大的时候无法存储:没有很好的备份机制:数据达到一定数量开始缓慢,很大的话基本无法支撑:因此我们需要探究更加合适的数据库来支撑我们的业务. HBase 什么是HBas ...