函数

函数的作用:

1、减少重复代码

2、扩展性强

3、使程序变的可维护

函数的定义:

def test():
print("I'm yao")
#def 是固定的,test为函数名一对小括号不可不少

函数的调用:

def test():
print("I'm yao") test() # 函数的调用
# 结果:
I'm yao

形参:

def test(x, y):
print("I'm yao")
print(x*y) test(5,6) # 函数的调用

实参:

关键字参数:

默认参数

参数组

函数的各种参数总结:

1、形参和实参是一 一对应的

2、关键字参数和形参的位置无关

3、关键字参数和实参同时出现,关键字参数永远放在实参的右边。

4、形参和默认参数同时出现,默认参数永远写在最右边

5、参数组永远放在最右边

嵌套式函数:

def test(x, y, z):
print(x, y, z)
def test1(a, b):
print(a, b)
test1(4, 5) # 调用嵌套函数
test(1, 2, 3) # 调用第一层函数

递归函数:

def fun(x):
if x // 2 > 0:
fun(x//2)
print(x) # x是个列表,一次打印
fun(10)
# 结果:
1
2
5
10

递归函数的特性:

1、必须有一个明确的结束调教

2、每次进入更深一层递归时,文图规模相比上次递归都应该有所减少

3、递归效率不高,递归层次过多会导致栈溢出。

函数的返回值:

作用:

1、一旦你的函数开始调用并开始执行,那你函数的外部程序就没有办法再控制函数的执行过程,此时玩不程序只能等待函数的执行结果。为什要等待函数的结果,因为外部程序要根据函数的执行结果来判断下一步该怎么走,这个结果就是以return的形式返回给外部程序。

2、return代表着函数的结束

3、return可以返回任意数据类型

4、对于用户来讲,函数可以返回任意数量的值,但对于python本身来讲,函数只能返回一个值,如果return后有多个值,那么结果返回也是一个值,这个值是以元组的形式存在的。

高阶函数:

变量可以指向函数,函数的参数能接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数就称之为高阶函数。

示例:

def add(x,y,z):
return z(x) + z(y)
test = add(3, -6, abs) # abs函数是绝对值
print(test)

内置函数:

局部变量和全局变量

局部变量:

在子程序中定义的变量是局部变量,在程序一开始定义的变量称为全局变量,全部变量的作用域是整个程序,局部变量的作用域是定义该变量的子程序,当全局变量与局部变量同名时,再多定义局部变量的子程序内,局部变量起作用,其他地方那个全局变量起作用。

全局变量:

在整个过程中都生效的变量叫做全局变量

示例:

x = 'xiaofeng'   # 全局变量
def case():
print(x)
y = 'oldboy' # 局部变量,出了这个函数就不能调用了
print(y) case()
print(x)
print(y)
# 结果
"C:\Program Files\Python35\python.exe" D:/python_progream/python_s15/day4/function_1.py
Traceback (most recent call last):
File "D:/python_progream/python_s15/day4/function_1.py", line 40, in <module>
print(y)
NameError: name 'y' is not defined # 因为y不是全局变量
xiaofeng
xiaofeng

匿名函数:

test = lambda x, y:(x + y)  # lambda定义匿名函数
print(test(3, 5))
# 结果
8

二分查找

data = [1, 3, 6, 7, 9, 12, 14, 16, 17, 18, 20, 21, 22, 23, 30, 32, 33, 35]

def binary_search(dataset, find_num):
print(dataset) if len(dataset) > 1:
mid = int(len(dataset) / 2)
if dataset[mid] == find_num: # find it
print("找到数字", dataset[mid])
elif dataset[mid] > find_num: # 找的数在mid左面
print("\033[31;1m找的数在mid[%s]左面\033[0m" % dataset[mid])
return binary_search(dataset[0:mid], find_num)
else: # 找的数在mid右面
print("\033[32;1m找的数在mid[%s]右面\033[0m" % dataset[mid])
return binary_search(dataset[mid + 1:], find_num)
else:
if dataset[0] == find_num: # find it
print("找到数字啦", dataset[0])
else:
print("没的分了,要找的数字[%s]不在列表里" % find_num) binary_search(data, 66)

三元运算+map函数

da = map(lambda n: n*2 if n > 5 else n, range(10))
for i in da:
print(i)
# 结果
0
1
2
3
4
5
12
14
16
18

三元运算示例

# 三元运算
a = 4
b = 5
d=a if a>10 else b
# 结果
5

函数式编程:

函数是python内建支持的一种封装,我们通过大段代码拆成函数,通过一层层的函数调用,就可以把复杂任务分解成简单的的任务,这种分解可以称为面向过程的设计。函数就是面向过程设计的基本单元。

函数式编程中的函数这个术语不是指计算机中的函数(实际上是Subroutine),而是指数学中的函数,即自变量的映射。也就是说一个函数的值仅决定于函数参数的值,不依赖其他状态。比如sqrt(x)函数计算x的平方根,只要x不变,不论什么时候调用,调用几次,值都是不变的。

Python对函数式编程提供部分支持。由于Python允许使用变量,因此,Python不是纯函数式编程语言。

一、定义

简单说,"函数式编程"是一种"编程范式"(programming paradigm),也就是如何编写程序的方法论。

主要思想是把运算过程尽量写成一系列嵌套的函数调用。举例来说,现在有这样一个数学表达式:

(1 + 2) * 3 - 4

    结果:5

传统的过程式编程,可能这样写:

    var a = 1 + 2;

    var b = a * 3;

    var c = b - 4;

函数式编程要求使用函数,我们可以把运算过程定义为不同的函数,然后写成下面这样:

var result = subtract(multiply(add(1,2), 3), 4);

这段代码再演进以下,可以变成这样

add(1,2).multiply(3).subtract(4)

这基本就是自然语言的表达了。再看下面的代码,大家应该一眼就能明白它的意思吧:

merge([1,2],[3,4]).sort().search("2")

因此,函数式编程的代码更容易理解。

要想学好函数式编程,不要玩py,玩Erlang,Haskell, 好了,我只会这么多了。。。

内置参数:

参数名

含义

abs()

绝对值

all()

判断一个列表所有的值是否都为真

any()

如果列表中一个为真,就返回真,空列表也是假

ascii()

显示ascii码表中的地方

bin()

把一个数字转换为二进制

bool()

判断真或假

bytes()

不可变类型

bytearray()

callable()

判断一个对象是否可以调用

chr()

ascii码对应的字符

classmethod()

ord()

字符转acsii对应的数字

compile()

把文件里的字符串解析成python的语法

complex()

实数转复数

delattr()

dict()

生成字典

dir()

默认打印当前模块的所有属性,如果传一个对象参数则打印当前对象的属性

divmod()

取余数

enumerate()

exec()

eval()

filter()

过滤

float()

浮点数

format()

格式化输出

forzenset()

getattr()

locals()

hasattr()

hash()

help()

帮助

hex()

16

id()

查看内存中的位置

input()

用户输入,例子input("aaa:") 等待用户输入

int()

整数

isinstance()

issubclass()

iter()

len()

获取长度(元组,列表,字符串)

list()

列表

map()

max()

求最大数

memoryview()

min()

求最小数

next():

下一行

object()

oct():

open()

打开文件的方法

pow():

print():

打印

property()

range()

定义一个范围,例子range(1,10),或者range(1,10,2)

repr():

reversed():

round():

五舍六入,例子:riund(2.5) == 3

set()

集合

setattr()

slice()

sorted():

排序

staticmethod()

str()

字符串

sum()

求和

super()

tuple()

元组

type()

查看类型(str表示字符串类型,lsit表示列表类型....)

vars()

默认打印当前模块的所有属性,如果传一个对象参数则打印当前对象的属性

zip()

__import__()

python3.5------day4--function的更多相关文章

  1. python3.x Day4 内置方法,装饰器,生成器,迭代器

    内置方法,就是python3提供的各种函数,可以认为是关键字,帮助进行一些列的牛x运算. abs()#取绝对值 all([])#可迭代对象中的所有元素都为True 则为True,只要至少一个为Fals ...

  2. Python3.5 day4作业:对员工信息文件,实现增删改查操作。

    需求: 1.可进行模糊查询,语法至少支持下面3种: 1.select name,age from staff_table where age > 22 2.select  * from staf ...

  3. python3 Flask -day4 自定义url转换器

    url传参可以限定参数的数据类型,例如:限定user_id数据类型为int @app.route('/user/<int:user_id>') def my_list(user_id): ...

  4. python3.x Day4 模块!!

    json and pickle模块 用途是为了持久化信息,这种持久化方式可以和其他程序语言兼容,一般都支持json,json只能持久化数据,pickle是python特有的方式,可以持久化所有信息和数 ...

  5. python之six用法

    six.PY2 返回一个表示当前运行环境是否为python2的boolean值 six.PY3 返回一个表示当前运行环境是否为python3的boolean值 import six,sys print ...

  6. SQL 中用户建立与权限授予

    SQL 中用户建立与权限授予 一.原有 如果大家对我的博客动态非常关注的话,应该又看到我弄了一个随机MAN信息的小工具.但是呢,那个工具还有待加强(显示效果不是那么的好). 所以我就希望可以显示一些简 ...

  7. Python学习(四)数据结构(概要)

    Python 数据结构 本章介绍 Python 主要的 built-type(内建数据类型),包括如下: Numeric types          int float Text Sequence ...

  8. 【Python | opencv+PIL】常见操作(创建、添加帧、绘图、读取等)的效率对比及其优化

    一.背景 本人准备用python做图像和视频编辑的操作,却发现opencv和PIL的效率并不是很理想,并且同样的需求有多种不同的写法并有着不同的效率.见全网并无较完整的效率对比文档,遂决定自己丰衣足食 ...

  9. 016.Python闭包函数以及locals和globals

    一 闭包函数 内函数使用了外函数的局部变量,并且外函数把内函数返回出来的过程叫做闭包,这个内函数叫做闭包函数 1.1 闭包函数语法 def outer(): a = 5 def inner(): pr ...

  10. 015.Python函数名的使用以及函数变量的操作

    一 函数名的使用 python中的函数可以像变量一样,动态创建,销毁,当参数传递,作为值返回,叫第一类对象.其他语言功能有限 1.1 函数名是个特殊的变量,可以当做变量赋值 def func(): p ...

随机推荐

  1. android模拟器没法通过localhost访问本地服务器的解决

    当android项目访问在一台服务器上的WEB服务时,没法通过localhost或者127.0.0.1来访问.模拟器把它自己作为了localhost,代码中使用localhost或者127.0.0.1 ...

  2. python---psutil

    系统性能信息模块psutil psutil是一个跨平台库,能够轻松实现获取系统运行的进程和系统利用率(CPU,内存,磁盘,网络等)信息,主要应用于系统监控,分析和限制系统资源及进程的管理,它实现了同等 ...

  3. 对c语言中malloc和free函数的理解

    最近在复习c语言的时候再次用到了malloc函数和free函数,此处着讲解一下自己对这两个函数的理解和认识. 一. malloc函数和free函数的基本概念和基本的用法 对于malloc函数: 1.  ...

  4. Format specifies type 'int' but the argument has type 'struct node *'

    /Users/Rubert/IOS/iworkspace/LineList/LineList/main.c::: Format specifies type 'int' but the argumen ...

  5. 用openvswitch配置跨节点的docker网络环境

    在一篇随笔中,我们已经尝试了在不依赖工具的情况下设置docker的ip,连我都想吐槽,MD单机都这么麻烦,在多机的环境中岂不是要了我的小命! 本文就是为了多机环境中各个节点的容器通信而做的,网络拓朴如 ...

  6. emacs配置eslint 语法检查.找不到node解决

    使用emacs配置eslint 当调用语法检查时报错 Suspicious state from syntax checker javascript-eslint: Checker javascrip ...

  7. 搭建jms的步骤和过程

    搭建jms 参考网摘: http://www.jianshu.com/p/98689164a041

  8. 坑人的MyEclipse之-修改JSP页面的JavaScript背景颜色

    MyEclipse开发JSP页面时,如果要写JavaScript代码, 背景颜色默认是白色!效果如下: 这种反人类的设计我已经无力吐槽了!要改为黑色的话可以通过下面的方法设置:

  9. Google protobuf proto文件编写规则

    转载自: http://blog.csdn.net/yi_ya/article/details/40404231 1. 简单介绍 protobuf文件:就是定义你要的消息(类似java中的类)和消息中 ...

  10. 利用sp_addlinkedserver实现远程数据库链接

    --查看当前链接情况: select * from sys.servers; --使用 sp_helpserver 来显示可用的服务器 Exec sp_helpserver --删除已经存在的某个链接 ...