函数

在函数之前,我们一直遵循者:面向过程编程,即:根据业务逻辑从上到下实现功能,开发过程中最常见的就是粘贴复制。代码就没有重复利用率。

例如:有好多的重复的代码

 if 条件:
发送指令
接收结果
elif 条件:
发送指令
接收结果
elif 条件:
发送指令
接收结果

如果我们将重复的代码提取出来

例如:代码简洁多了

 def 一条操作(参数):
发送指令
接收结果 if 条件:
一条操作
elif 条件:
一条操作
elif 条件:
一条操作

对于以上两种方式,第二种明显要优于第一种,重用性可读性大大增加。这就是函数式编程和面向过程编程的区别

  • 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅仅调用函数即可。
  • 面向对象:对函数进行分类和封装。
  • 函数式编程最重要的是增强代码的重用性和可读性

1.函数的定义和使用

1.定义:

 def 函数名(参数):

     函数体

     返回值(默认不写,返回值为空)

函数的定义要点:

  • def:定义函数的关键字
  • 函数名:之后会根据函数名对函数进行调用
  • 函数体:函数中进行一系列的逻辑计算
  • 参数:为函数提供数据
  • 返回值:当函数执行完毕后,用于给调用者返回数据,默认为空

2.参数:

为什么要有参数呢?

 def 操作(参数):
发送一条指令('ls') if 条件:
操作()
elif 条件:
操作() # 不管是if还是elif,发送的都是同一条指令ls

无参数例子

 def 函数(参数):
执行指令(参数) if 条件:
函数(ls)
elif 条件:
函数(pwd)

有参数的例子

函数中有三种不同的参数:

  • 普通参数
  • 默认参数
  • 动态参数
 #************定义****************
#name 叫做函数func的形式参数,简称:形参
def func(name):
print(name) #************调用****************
# 'nullnull'叫做func的实际参数,简称:实参
func('nullnull')

普通参数

 def func(name,age=20)
print(name,age) # 指定参数
func('nullnull',18)
func(name="nullnull",age=20) #使用默认参数
func("null")

默认参数

 def func(*args):
print(args) #执行方式一
func(1,2,3,4,5,6,7) #执行方式二
li = [1,2,3,4,5,6,7]
func(*li)

动态参数args

 def func(**kwargs):
print(kwargs) # 执行方式一
func(name="nullnull",age=18) # 执行方式二
dic = {'name':'nullnull','age':18}
func(**dic)

动态参数kwargs

特别的,普通参数,默认参数,动态参数是有顺序要求的

 def func(普通参数,默认参数,*args,**kwargs):
pass

参数的顺序要求

Python的内置函数

函数详解

Lambda表达式

对于简单的函数,有一种简便的表示方式,即:lambda表达式

 #*************普通函数**************
#定义函数
def func(arg):
print(arg) #执行函数
func('null') #*************lambda***************
#定义函数(lambda表达式)
my_lambda = lambda arg : arg + 1 #执行函数
my_lambda(0)

递归

利用Python编写斐波那契数列:

  斐波那契数列:0,1,1,2,3,5,8,13......

 def func(arg1,arg2):
if arg1 == 0:
print(arg1,arg2)
arg3 = arg1 + arg2
print(arg3)
func(arg2,arg3) func(0,1)

补充:三元运算符 

三元运算(三目运算),是对简单的条件语句的缩写

 result = 值1 if 条件 else 值2

 #如果条件成立,那么result = 值1,否则result = 值2

补充:深浅拷贝

对于数字 字符串而言,赋值、浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址

 import copy

 n1 = 1

 #查看n的内存地址
print(id(n1)) #将n1赋值给n2
n2 = n1
print(id(n2)) #浅拷贝
n3 = copy.copy(n1)
print(id(n3)) #深拷贝
n4 = copy.deepcopy(n1)
print(id(n4)) 你会神奇的发现打印的都是相同的

对于字典、元组、列表 而言,进行赋值、浅拷贝、深拷贝时,其内存地址的变化时不一样的

1.赋值

 n1 = {"k1":'nullnull',"k2":1,"k3":['hello','python']}

 n2 = n1

2.浅拷贝

浅拷贝,在内存中额外创建 第一层 的数据

 import copy

 n1 = {"k1":"nullnull","k2":1,"k3":["hello","python"]}

 n2 = copy.copy(n1)

3.深拷贝

深拷贝,在内存中将所有的数据重新创建一份(排除最后一层,即:Python内部对字符串和数字的优化)

 import copy

 n1 = {"k1":"nullnull","k2":1,"k3":["hello","python"]}

 n2 = copy.deepcopy(n1)

我的Python升级打怪之路【三】:Python函数的更多相关文章

  1. 我的Python升级打怪之路【一】:python的简单认识

    Python的简介 Python与其他语言的对比: C和Python.Java.C# C语言:代码直接编译成了机器码,在处理器上直接执行 Python.Java.C#:编译得到相应的字节码,虚拟机执行 ...

  2. 我的Python升级打怪之路【七】:网络编程

    Socket网络套接字 socket通常也称为"套接字",用于描述IP地址和端口,是一个通信链的句柄.应用程序通常通过”套接字“向网络发出请求或者应答网络请求. socket起源于 ...

  3. 我的Python升级打怪之路【六】:面向对象(二)

    面向对象的一些相关知识点 一.isinstance(obj,cls) 检查实例obj是否是类cls的对象 class Foo(object): pass obj = Foo() isinstance( ...

  4. 我的Python升级打怪之路【六】:面向对象(一)

    面向对象的概述 面向过程:根据业务逻辑从上到下写代码 函数式:将其功能代码封装到函数中,日后便无需编写,仅仅调用即可 [执行函数] 面向对象:对函数进行分类和封装.[创建对象]==>[通过对象执 ...

  5. 我的Python升级打怪之路【五】:Python模块

    模块,是一些代码实现了某个功能的集合 模块的分类: 自定义模块 第三方模块 内置模块 导入模块 import module from module.xx.xx import xx from modul ...

  6. 我的Python升级打怪之路【四】:Python之前的一些补充

    字符串的格式化 1.百分号的方式 %[(name)][flags][width].[precision]typecode (name) 可选,用于选择指定的key flags 可选,可供选择的值有: ...

  7. 我的Python升级打怪之路【二】:Python的基本数据类型及操作

    基本数据类型 1.数字 int(整型) 在32位机器上,整数的位数是32位,取值范围是-2**31~2--31-1 在64位系统上,整数的位数是64位,取值范围是-2**63~2**63-1 clas ...

  8. gitlab 迁移、升级打怪之路:8.8.5--> 8.10.8 --> 8.17.8 --> 9.5.9 --> 10.1.4 --> 10.2.5

    gitlab 迁移.升级打怪之路:8.8.5--> 8.10.8 --> 8.17.8 --> 9.5.9 --> 10.1.4 --> 10.2.5 gitlab 数据 ...

  9. Python全栈之路4--内置函数--文件操作

    上节重点回顾: 判断对象是否属于某个类,例如: 列表中有个数字,但是循环列表判断长度,用len会报错;因为int不支持len,所以要先判断属于某个类,然后再进行if判断. # isinstance(对 ...

随机推荐

  1. 第二章第一个项目——package.json

    在其中写版本好的时候, { "name": "chatroom", "version": "0.0.1", " ...

  2. HBase介绍 (1)---数据模型

    http://blog.csdn.net/heyutao007/article/details/5766896 BigTable是什么?Google的Paper对其作了充分的说明.字面上看就是一张大表 ...

  3. Java集合框架(Collection Framework)学习之 HashMap

    从API文档可以得到HashMap的以下几个特点: 基于哈希表(hash table)实现,并且是链式哈希表 允许空值和空键(null=null 键值对) HashMap与Hashtable基本相同, ...

  4. [IE bug] ajax请求 304解决方案

    最近和筒子们做了个校园电台,进去之后会自动播放歌曲,每首放完了的话会随机get新的json,然后再播放下一首 整体做成了命令行的风格,在最后输入next,start等命令来操作,5+M/s校园网+W级 ...

  5. 百万数据测试 Entity Framework 到底有多慢

    测试环境 硬件:阿里云乞丐配置 操作系统:Centos 7 CPU: 1核 内存:1 GB (I/O优化) 网络:1Mbps(峰值) 软件 .net core 2.0 ZKEACMS For .net ...

  6. Spring各个jar包详解

    Spring各jar包详解 spring.jar 是包含有完整发布模块的单个jar 包.但是不包括mock.jar,aspects.jar, spring-portlet.jar, and sprin ...

  7. IoC概要

    控制反转基本上说的是功能调用者与功能实现者之间应该如何交互,即二者之间没有直接的强耦合(调用者new一个被调用者),而是都依赖同一个抽象,这个抽象规定了二者交互的接口.反转的意思是实现了依赖倒置,在程 ...

  8. HTML中DOM元素的子节点为空?!firstChild, lastChild, childeNodes[]为空

  9. [译文]casperjs使用说明-测试

    capserjs自带了一个测试框架,它提供了一个使你能够更容易的测试你的web应用的工具集. 注意: 1.1版本变更 这个测试框架,包括它的所有API,仅能使用在casperjs test子命令下 如 ...

  10. CentOS6.9 ARM虚拟机扩容系统磁盘

    由于扩容磁盘的操作非同小可,一旦哪一步出现问题,就会导致分区损坏,数据丢失等一系列严重的问题,因此建议:在进行虚拟机分区扩容之前,一定要备份重要数据文件,并且先在测试机上验证以下步骤,再应用于您的生产 ...