Python学习笔记----Python进阶

本文探讨了Python的函数式编程概念,包括高阶函数如map、reduce、filter和sorted,以及闭包、lambda表达式和装饰器的使用。同时,还介绍了Python的类,包括属性、方法、初始化、访问控制以及类的特性,如继承、多态和定制类的方法。
摘要由CSDN通过智能技术生成

一、python 之 函数式编程
  1. 高阶函数
    ① 变量可以指向函数,函数名就是指向函数的变量。

    ② 可以接受函数作为参数的函数为高阶函数。

    def add(x, y, f):
    	return f(x) + f(y)
    print add(-1, 2, abs)
    # 输出结果
    # 3
    
  2. 内置高阶函数
    map() 接收一个函数 f 和一个 list,并通过把函数 f 依次作用在 list 的每个元素上,得到一个新的 list 并返回。

    def fact(x):
    	return x * x
    data = range(1, 11)
    print map(fact, data)
    # 输出结果
    # [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
    

    reduce() 接收一个函数 f 和一个 list,但是 函数 f 必须接受两个参数;作用是对 list 的每个元素反复调用函数 f ,并返回最终结果值;还可以接受第三个参数作为初始值。

    def f(x, y):
    	return x * x + y * y
    data = range(1, 5)
    print reduce(f, data)
    print reduce(f, data, 2)
    # 输出结果
    # 1172
    # 722516
    

    filter() 接收一个函数 f 和一个list,函数 f 的作用是对每个元素进行判断,返回 True或 False;filter() 根据判断结果自动过滤掉不符合条件的元素,返回由符合条件元素组成的新list 。

    # 过滤出 1~100 中平方根是整数的数字
    import math
    def is_sqr(x):
    	ans = int(math.sqrt(x))
    	return ans * ans == x
    data = range(1, 101)
    print filter(is_sqr, data)
    # 输出结果
    # [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
    

    sorted() 为自定义排序函数:比较函数的定义是,传入两个待比较的元素 x, y,如果 x 应该排在 y 的前面,返回 -1;如果 x 应该排在 y 的后面,返回 1;如果 x 和 y 相等,返回 0。

    # 从大到小排序
    def my_cmp(x, y):
    	if x > y:
    		return -1
    	if x < y:
    		return 1
    	return 0
    data = [43, 12, 98, 65, 25, 19]
    print sorted(data, my_cmp)
    # 输出结果
    # [98, 65, 43, 25, 19, 12]
    
  3. 闭包
    ① 内层函数引用了外层函数的变量(参数也算变量),然后返回内层函数的情况,称为闭包(Closure)。

    # 外层函数
    def f():
        print 'call f()...'
        # 定义内层函数g:
        def g()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值