纯函数式编程是没有变量的,只要输入确定输出就确定 指高度抽象的编程范式

特点 函数本身可以作为参数传入 或者允许返回一个函数

Higher-order function 一个函数可以接收另一个函数作为参数

函数名其实就是指向函数的变量

map(func_name, Iterable) 序列的每一个元素依次传参给func 并将结果作为新的Iterator返回

reduce(func_name,  序列)func接收两个参数 并把结果继续和序列的下一个元素做累积计算

map的一个参数的函数只有一个参数 reduce的第一个参数函数有两个参数

filter(func, sequence)sequence元素一次作用func根据返回的True False 保留 最后返回一个Iterator

is 判断指向是否同一个 ==判断值是否相等

sorted(iterable, /, *, key=None, reverse=False)按照key函数返回结果进行排序 reverse反转 key作用的是序列的每一个元素

闭包 返回一个函数 返回的这个函数引用了外部函数的变量

返回闭包时 返回函数不要引用任何循环变量 或者后续会发生变化的变量

lambda匿名函数只能有一个表达式不用写return 返回值是表达式的结果

dir()查看对象有哪些属性 id()查看内存地址 函数名相当于一个内存地址 加了括号就相当于调用 .__name__看函数名字 .__iter__看是否可迭代

装饰器 代码运行期间动态增加功能的方式 本身是一种闭包但decorator的形参必须是函数

嵌套函数 函数要被调用才会执行 即出现func()才会执行

闭包 当调用外部函数时 返回的结果是内部函数的内存地址 调用内部函数才会返回运算结果

闭包 外部函数()()返回的内部函数的运算结果 相当于第一次调用外部函数 第二次调用内部函数

其实装饰器就相当于 装饰器的外部函数()() 就内部函数执行结果  装饰器函数如果是三层嵌套就相当于最外部函数()()() 两层嵌套就相当于外部函数()() 第几个括号有参数就第几次调用传参

装饰之后 相当于被装饰的函数指向了装饰器的内部函数(返回函数) 所以其函数名.__name__实际就是内部函数

import functools

@functools.wraps(func)是把原始函数的__name__等属性还回去  定义在内部函数的前面 即传参是被装饰函数的那个函数里面

如果打印函数 会把函数的None打印出来 eg:print(func())

print 和return区别 函数的返回值return语句只有在打印的时候才把值打出来

x = func() 指x接收函数的返回值 并执行一遍函数 return func() 指返回func()函数的返回值 并没有说要打印返回值哦 并执行一遍func()

如果装饰器本身需要传参 就多一层嵌套函数 该参数和被装饰函数 算是两个位置参数一起传给装饰器函数

偏函数 new = functools.partials(old, kw) 固定原函数的部分参数 创建新函数

if __name__ = __main__ :  该模块被执行时为真 被导入时为假

前缀 _ 是private函数或变量 一般在公开函数中调用私有函数

def str2float(s):
DIGITS = {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}

def char2num(string):
return DIGITS[string]

index = [i for i, x in enumerate(s) if x == '.']
if len(index) > 1:
raise TypeError("类型错误,非有效数字")
if len(index) == 1:
index = index[0]
front = s[:index]
end = s[index + 1:]
return reduce(lambda x, y: x * 10 + y, map(char2num, front)) + (reduce(lambda x, y: x / 10 + y, map(char2num, end[::-1]))) / 10
else:
return reduce(lambda x, y: x * 10 + y, map(char2num, s))

notes for lxf(三)的更多相关文章

  1. notes for lxf(五)

    类和实例的绑定方法和属性 实例绑定 obj.func = func obj.func(obj, &argv)  obj.func = MethodType(func, obj) 第一个参数是方 ...

  2. notes for lxf(四)

    类名首字母通常大写 创建实例 类名 +() __init__方法 创建实例时把一些属性绑上去 __init__方法第一参数永远是self 表示船舰的实例本身 类是实例的模板 实例是一个一个具体的对象 ...

  3. notes for lxf(二)

    函数 abs()绝对值 max()返回最大值 raise 后接异常类 引发异常 函数返回多个值其实就是返回一个tuple 函数默认返回None 如果有必要检查参数类型用isinstance() typ ...

  4. notes for lxf(一)

    python代码不能用word和windows自带的记事本保存 word保存的不是纯文本文件 记事本会在文件开始的地方加上特殊字符(UTF-8 BOM) 交互模式启动了解释器 直接运行.py文件是一次 ...

  5. Linux时间子系统之(六):POSIX timer

    专题文档汇总目录 Notes:首先讲解了POSIX timer的标识(唯一识别).POSIX Timer的组织(管理POSIX Timer).内核中如何抽象POSIX Timer:然后分析了POSIX ...

  6. Linux kernel的中断子系统之(八):softirq

    返回目录:<ARM-Linux中断系统>. 总结:中断分为上半部和下半部,上半部关中断:下半部开中断,处理可以延迟的事情.下半部有workqueue/softirq/tasklet三种方式 ...

  7. Core Services层

    本文转载至 http://jingyan.baidu.com/article/cdddd41c57360853cb00e124.html Core Services层是系统很多部分的基础部分,也许应用 ...

  8. django notes 三:Template 的查找

    django 中有 2种 Template Loader django.template.loaders.filesystem.Loader django.template.loaders.app_d ...

  9. Android Weekly Notes Issue #229

    Android Weekly Issue #229 October 30th, 2016 Android Weekly Issue #229 Android Weekly笔记, 本期内容包括: 性能库 ...

随机推荐

  1. Helm包管理工具(简介、安装、方法)

    认识Helm 每次我们要部署一个应用都需要写一个配置清单(维护一套yaml文件),但是每个环境又不一样.部署一套新的环境成本是真的很高.如果我们能够使用类似于yum的工具来安装我们的应用的话那就太好了 ...

  2. C++回顾day03---<string字符串操作>

    一:string优点 相比于char*的字符串,C++标准程序库中的string类不必担心内存是否足够.字符串长度等等 而且作为一个类出现,他集成的操作函数足以完成我们大多数情况下的需要. 二:str ...

  3. 树莓派的系统安装,并且利用网线直连 Mac 进行配置

    最近单位给了我一个新的树莓派3B+让我自己玩.下面是我记录的我如何安装 Raspbian Stretch Lite 系统,然后如何成功不用独立显示屏而利用 MacBook 对其进行配置. 安装 Ras ...

  4. express session 和 socketio session关联

    express session http是没有状态的协议, 需要web框架自己实现会话和会话管理工作. express框架有session插件可以使用. 见如下介绍: https://www.tuto ...

  5. python3 练手实例3 摄氏温度与华氏温度转换

    def wd(): w=input('请输入一个摄氏温度或者一个华氏温度,如,34c/C or 34f/F:') if w[-1] in ['c','C']: w=float(w[:-1]) hs=1 ...

  6. Exp1:PC平台逆向破解 20164314 郭浏聿

    一.实践目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数会简单回显任何用户输入的字符串. 该程序同时包含另一个代码片段,getS ...

  7. APP数据的爬取

    前言 App 的爬取相比 Web 端爬取更加容易,反爬虫能力没有那么强,而且数据大多是以 JSON形式传 输的,解析更加简单.在 Web 端,我们可以通过浏览器的开发者工具监听到各个网络请求和响应过程 ...

  8. 后端视角下的前端框架之Vue.js初探

    背景 作为常年搞后端的自己来说,除了多年前学习的一点关于HTML的皮毛,对现在的前端技术栈可谓是一窍不通.但是因为最近在做的内部业务全链路监控系统,负责前端的同事做到一半去搞别的项目了,为了把项目落地 ...

  9. Win2012 R2安装 mysql8.0

    1.官网下载安装 官网上面写着x86,其实是兼容x64和x86的,下载安装就行 2.安装navicat 3.navicat连接mysql的时候出现错误 client does not support ...

  10. Input子系统(二)【转】

    转自:http://blog.chinaunix.net/uid-25047042-id-4192368.html 上一篇中粗略的分析了下input_dev,input_handle,input_ha ...