函数浅析:可以减少代码重用,保持一致性,可扩展性,易维护性。

定义方法: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!的更多相关文章

  1. python从入门到精通之30天快速学python视频教程

    点击了解更多Python课程>>> python从入门到精通之30天快速学python视频教程 课程目录: python入门教程-1-Python编程语言历史及特性.mkv pyth ...

  2. Python从入门到精通之eighth!

    函数式编程与内置函数 函数作用域: def test1(): print('in the test1') def test(): print('in the test') return test1() ...

  3. Python从入门到精通之Sixth!

    补充:enumerate 函数用于遍历序列(元组tuple.列表list.字典dict)中的元素以及它们的下标: >>> for i,j in enumerate(('a','b', ...

  4. Python从入门到精通之Forth!

    Python基本数据类型之列表 补充:range()方法 python2: range   立即创建 xrange  for循环的时候才一个一个创建 Python3: range     for循环的 ...

  5. Python从入门到精通之Third!

    Python运算符 算数运算符:+    -    *   /     %    //    **  比较运算符:==    >     <     >=   大于等于      & ...

  6. Python从入门到精通之Second!

    初识Python基础! -基础     -扩展名可以是任意的,但是导入模块时,如果不是.py文件就会报错. -两种执行方式      1.python解释器       文件名.py 文件路径 -Li ...

  7. Python从入门到精通之First!

    Python的种类 Cpython Python的官方版本,使用C语言实现,使用最为广泛,CPython实现会将源文件(py文件)转换成字节码文件(pyc文件),然后运行在Python虚拟机上. Jy ...

  8. Python从入门到精通之环境搭建

    本章内容: Windows系统环境搭建 Linux系统环境搭建 Mac OS系统环境搭建 一.下载python安装包 下载地址:https://www.python.org/downloads/ 二. ...

  9. Python从入门到精通之Fifth!

    字典  类名:dict   字典是无序的. 字典的创建  info = {"k1":{1:"abc",[1,2,3]},"k2":True} ...

随机推荐

  1. supervisord的安装使用

    由于生产环境使用的的tomcat,项目比较重要,所以要做进程守护,本来打算自己写脚本,但是效果不理想,想了下还是用supervisord了 由于很久不用,所以写下来部署步骤 第一:安装,安装的方法有y ...

  2. IDEA中MAVEN项目Dependency not found 问题

    STEP1: 更新IDEA保存的仓库索引.操作步骤File->Setting->Maven->Repositories->Update.dependecy not found问 ...

  3. CSS属性相关

    ·一.宽和高 width属性可以为元素设置宽度. height属性可以为元素设置高度. 块级标签才能设置宽度,内联标签的宽度由内容来决定. 二.字体属性 1.文字字体 font-family可以把多个 ...

  4. Object备忘录

    1.Object.assign(target,...source) 方法用于将所有可枚举属性的值从一个或多个源对象复制到目标对象.它将返回目标对象. 2.Object.create()方法创建一个新对 ...

  5. python入门(十):模块、包

    模块:py文件包:目录,目录里面包含__init__.py,内容可以是空里面可以包含多个模块文件,还可以包含子包 1.模块和包,可以很方便的提供给其他程序以复用 1) 利于组织复杂工程 我们写代码的时 ...

  6. ssh登录locale报错:cannot change locale (zh_CN.UTF-8): No such file or directory

    一.登录ssh报错: Last :: from 172.28.146.109 -bash: warning: setlocale: LC_ALL: cannot change locale (en_C ...

  7. flask 需要下载的包

    Flask 需要下载的包1.pip install flask2.pip install flask-script3.pip install flask-sqlalchemy4.pip install ...

  8. Java框架spring Boot学习笔记(六):Spring Boot事务管理

    SpringBoot和Java框架spring 学习笔记(十九):事务管理(注解管理)所讲的类似,使用@Transactional注解便可以轻松实现事务管理.

  9. 并发编程 process 模块的方法及运用 僵尸与孤儿

    进程创建的两种方法 Process() 继承Process 重写run方法,传参数的时候要写init,但是注意要在init方法中运行父类的init方法 Windows下写代码开启子进程时,必须写上if ...

  10. 红黑树(red-black tree)实现记录

    https://github.com/xieqing/red-black-tree A Red-black Tree Implementation In C There are several cho ...