函数式编程与内置函数

函数作用域:

def test1():
print('in the test1')
def test():
print('in the test')
return test1() res = test()
print(res()) =========因为test中没有return值,所以默认为NONE.
name = 'alex'
def foo():
name='xtjiayou'
def bar():
print(name)
return bar
a = foo()
print(a)
#return bar与return bar()不同,第一个是返回函数的内存地址,第二个是返回
xtjiayou
None name = 'alex'
def foo():
name='linhaifeng'
def bar():
print(name)
return bar
a = foo()
print(a)
a() #a()执行bar内存地址不所存储的代码 ===========
<function foo.<locals>.bar at 0x000002067F719840>
linhaifeng

注意:以上面代码为准foo()()相当于执行了a =foo()  a()的作用。依次类推若有多层return 函数名(没有括号),可以使用多个括号,进行执行内存地址中代码。

示例:

def foo():
name = 'xtznb'
print(name)
def bar():
name = 'xtcnb'
print(name)
def tt():
print(name)
return tt
return bar
r1 = foo()
r2 = r1()
r3 = r2()
==============#或者把后三句改为r1 = foo()()()
xtznb
xtcnb
xtcnb

匿名函数:不应该独立存在,应该与其他函数共同使用。

定义方法:lambda 形式参数: 代码

 #利用赋值语句,进行引用匿名函数,但一般不这么用。
func = lambda x:x+1
print(func(10)) name = 'alex'
def change_name():
return name+'_sb' fo = lambda x:x+'_sb'
fo(name)
==========>>alex_sb 匿名函数和自定义函数作用一样,但更简洁,只能使用一行代码。

编程方法论:面向过程、函数式、面向对象

函数式编程:编程语言定义的函数 + 数学意义的函数

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

而函数式编程(请注意多了一个“式”字)——Functional Programming,虽然也可以归结到面向过程的程序设计,但其思想更接近数学计算。

我们首先要搞明白计算机(Computer)和计算(Compute)的概念。

在计算机的层次上,CPU执行的是加减乘除的指令代码,以及各种条件判断和跳转指令,所以,汇编语言是最贴近计算机的语言。

而计算则指数学意义上的计算,越是抽象的计算,离计算机硬件越远。

对应到编程语言,就是越低级的语言,越贴近计算机,抽象程度低,执行效率高,比如C语言;越高级的语言,越贴近计算,抽象程度高,执行效率低,比如Lisp语言。

函数式编程就是一种抽象程度很高的编程范式,纯粹的函数式编程语言编写的函数没有变量,因此,任意一个函数,只要输入是确定的,输出就是确定的,这种纯函数我们称之为没有副作用。而允许使用变量的程序设计语言,由于函数内部的变量状态不确定,同样的输入,可能得到不同的输出,因此,这种函数是有副作用的。

函数式编程的一个特点就是,允许把函数本身作为参数传入另一个函数,还允许返回一个函数!

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

高阶函数:满足1.函数接受的参数是一个函数名 2.返回值中包含函数

#返回值中包含函数
def foo():
print('from foo')
return bar
def bar():
print('from bar') n = foo()
n()
def handle():
print('from handle')
return handle()
handle()
======================
from foo
from bar
from handle

函数尾调用:在函数最后一步调用另外一个函数(最后一行不一定是函数的最后一步)

def test(x):
if x > 1:
return True
elif x == 1:
return False
else:
return True
n = input('please a number')
print(test(int(n,10))) #尾调用示例 True
  • map函数依次处理每个列表元素
  • filter函数依次筛选列表的每一个值,最后得一个列表
  • reduce函数把两个完整的序列压缩到一起

map函数

注意
num_l = [1,2,3,4,5,6]
def add_one(x):
return x+1
def reduce_one(x):
return x-1
def pf(x):
return x**2
def map_test(func,array): ret = []
for i in num_l:
res = add_one(i)
ret.append(res)
return ret
print(map_test(reduce_one,num_l)) #终极版本
def map_test(func,array):
ret=[]
for i in num_l:
res=func(i)
ret.append(res)
return ret print(map_test(lambda x:x+1,num_l)) map内置高级函数用法
num_l=[1,2,3,4,5]
print(list(map(lambda x:x+1,num_l)))
msg='linhalifneg'
print(set(map(lambda x:x.upper(),msg)))


filter函数

#过滤函数的功能
movie_people = ['alex','wupe_sb','xsss_sb','sql_sb'] def sb_show(n):
return n.endswith('sb')
def filter_test(func,array):
ret = []
for p in array:
if not func(p):
ret.append(p)
return ret
res = filter_test(sb_show,movie_people)
print(res) #filter函数格式:filter(过滤方法,可迭代变量)
#过滤方法可以是匿名函数
movie_people = ['alex','wupe_sb','xsss_sb','sql_sb'] res = filter(lambda n:not n.endswith("_sb"),movie_people)
print(list(res)) =======>>['alex']

reduce函数

from functools import reduce 从此模块中导入reduce函数

#可以起到reduce作用
num_l=[1,2,3,100]
def reduce_test(array):
res=0
for num in array:
res+=num
return res
print(reduce_test(num_l))
#终极版的reduce功能
numl=[1,2,3,100] lambda x,y:x*y,numl
def multi(x,y):
return x*y num_l=[1,2,3,100] def reduce_test(func,array):
res=array.pop(0) #取出第一个值,以便进行下面运算
for num in array:
res=func(res,num)
return res
print(reduce_test(lambda x,y:x*y,num_l)) #指定起始值,在进行运算 注意:init不是替代第一个而是被添加到第一个
num_l=[1,2,3,100] def reduce_test(func,array,init=100):
if init is None:
res=array.pop(0)
else:
res=init
for num in array:
res=func(res,num)
return res print(reduce_test(lambda x,y:x*y,num_l)) #reduce函数 注意:reduce(某功能函数,可迭代变量,起始值)
from functools import reduce
num_l=[1,2,3,100]
print(reduce(lambda x,y:x*y,num_l,2))

 内置函数

bool()    #转换为布尔值   空,None,0为假值
int() #转换为整型
float() #转换为浮点型数据
len() #测试字符串长度或者统计可迭代对象的元素个数
list() #转换为列表
tulple() #转换为元组
dict() #转换为字典
set() #转换为集合
str() #转换为字符串型
例如:dic={'name':'alex'}
dic_str=str(dic) ===》‘{‘name’:‘Alex’}’ hex() #十进制转16进制
oct() #十进制转8进制
id() #打印对象的内存地址
input() #输入字符
isinstance() #判断值与类型是否一致 globals() #打印全局变量
locals() #打印局部变量 abs() #绝对值函数
all() #若一个为假即为假,全真即为真 注意只能有一个参数,可以是列表
any() #任意一个为真即为真
chr() # 把ASCII码值转为对应的字符 chr(97) ====>>A
ord() #与chr()正好相反,通过字符转换为ASCII码值
pow(x,y) #x的y次幂,若是3个参数则对第三个进行取余运算。
round(3.5)#四舍五入函数,===》4
reversed()#反转序列,前面加上个可迭代对象才能看出来
sorted() #排序,默认升序,注意:;不同类型不能排序 max() #取最大值 ha=[1,2,199,-1] max(ha)===>>199
min() #取最小值
age_dic = {'age1':18,'age2':81,'age3':11,'age4':28,'age5':180}
print(max(age_dic.values()))
#不同类型不能进行比较,字典不能比较,因为它是无序的
l=['a10','b12',100]
print(list(max(l))) #拉链函数,产生生一个内存对象,可利用列表、元组等可迭代对象进行输出,注意一一对应输出
zip(('a','b','c'),(1,2,3)) =======》[('a',1),('b',2),('c',3),]
例如:若要使字典中key与value一一对应
p={'name':'alex','age':18,'gender':'none'}
print(list(zip(p.keys(),p.values())))
===>>[('name', 'alex'), ('age', 18), ('gender', 'none')]
dir(byte('我是gbk编码',encoading='gbk'))  #打印某一对象中有哪些属性与方法
help() #打印帮助信息,用于查看函数是干什么的

slice(初始,结束,步长) #定义切片,可读性好
li='hello'
s = slice(2,5,2)) ====>lo
s.start s.stop s.step =====>> 2 5 2 frozenset() #返回一个冻结的可迭代对象,冻结后序列不能再添加或删除任何元素 divmod(10,3)==>(3,1) #多用于分页,结果左侧表示一共多少页,右侧表示剩下多少条记录
eval() #1.提取出字符串中的数据结构, 2.把字符串表达式进行运算
express='1+2*(3/3-1)-2'
print(eval(express)) ====》-1.0 #把字符串转换为字节形式,必须进行编码,也可以进行解码。注意:utf-8编码使一个字符等于3个字节,gbk 一个字符等于两个字节,ASCII码不能编码中文
bytes('你好',encoading="utf-8") #解码:用什么编码就用什么解码 默认解码是gbk
bytes('hello,boy!',encoading='utf-8').decode('utf-8') hash() #进行哈希运算,可哈希的数据类型即不可变数据类型,不可变哈希类型即可变数据类型。不管输入数据多大,哈希值都定长,不可根据哈希值逆推回字符串。注意:哈希可用于判定软件木马,当下载一个软件包时产生一个哈希值,当安装时又产生一个,两个相互对比可判断是否被添加了木马或其他信息。

max、min函数高级用法

1.max函数处理的是可迭代对象,相当于一个for循环去除每个元素进行比较,注意:不同类型之间不能进行比较
2.每个元素间进行比较,都是从第一个位置依次比较。
people=[
{'name':'王八','age':1000},
{'name':'龟','age':10000},
{'name':'九千岁','age':9000},
{'name':'alex','age':18}
] print(max(people,key=lambda dic:dic['age'])) ret=[]
for item in people:
ret.append(item['age'])
print(ret)
max(ret)
sum函数:求和函数   例如:sum(range(5)) sum(可迭代对象)
locals()  打印局部变量,以字典形式
vars([object]) 返回是字典形式,若没有参数相当于locals()函数,若有参数(str、int。。。)则将其所以方法存入字典形式 _import_() 导入模块,模块就是py文件
#test.py
def sya_hi():
  print('hello,handsome young man!')

import test
tst.say_hi()

_import_('test')  #按字符串样式导入模块
import() #不能调用字符类型模块

Python从入门到精通之eighth!的更多相关文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  8. Python从入门到精通之Seventh!

    函数浅析:可以减少代码重用,保持一致性,可扩展性,易维护性. 定义方法:def 函数名(形参):     '''功能注释'''      代码块 打印函数名时,会出现函数的内存地址.两个函数名相同时, ...

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

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

随机推荐

  1. TCPlayer web切换播放问题

    遇到播放的视频无法切换的问题,,即便是清除标签重新生成也不行~~ 需要使用自带的API ~别无他法 demo: http://imgcache.qq.com/open/qcloud/video/tcp ...

  2. css note

    1.text-align规定了其子元素的对齐方式,当设置在子元素无效时,尝试设置在父元素,子元素可以水平居中: 2.vertical-align使用的前提,首先元素必须是display:inline ...

  3. 循环列表最后一条不显示borderBottom

    You could achieve this using some logic: return books.map((book, i) => { return( <View style={ ...

  4. cron表达式学习

    一.Cron 是计划任务(定时任务) 二.Cron表达式 Cron表达式是一个字符串,分为6或7个域,每个域用空格分开.Cron有如下两种语法格式: (1) Seconds Minutes Hours ...

  5. Windows10安装pycocotools方法,亲测可用!

    如果遇到:No module named 'pycocotools' 错误,说明你的环境需要安装pycocotools,以下介绍在Windows10下安装pycocotools的方法,这是本人结合看过 ...

  6. k8s 代码生成

    https://blog.openshift.com/kubernetes-deep-dive-code-generation-customresources/ # 代码生成的工作目录,也就是我们的项 ...

  7. Mysql数据存在更新,不存在则插入的实现

    有些情况下,我们需要对数据库进行插入或更新操作的时候需要先根据特定的字段去判断是否已存在,然后做出不同的插入或者跟新操作. replace函数: 我们要在需要判断的字段上建立一个唯一索引,且这个字段不 ...

  8. SDL2.0 vs2017环境配置

    到SDL的官网下载VC++的Development Libraries. 新建一个项目,进入属性窗口. VC++目录->包含目录加入include所在路径,库目录加入lib\x86所在路径. 链 ...

  9. unity插件各领域王者

    移动端手势操作 Easy Touch 获取 缓动 iTween 获取 可视化编程 Playmaker1.9.0 获取 UI NGUI,UGUI 获取 Shader着色器可视化编程 AmplifySha ...

  10. FortiGate 服务License注册步骤

    1. 产品服务license文档 购买服务后,用户会收到一份PDF文档<Service Registration Document>,内有如下内容: 2. 登陆 https://suppo ...