zoukankan      html  css  js  c++  java
  • lambda函数

    一.lambda函数介绍(匿名函数)

    >>> def f(x):
    ...     return x*2
    ...     
    >>> f(3)
    6
    >>> g = lambda x: x*2  
    >>> g(3)
    6
    >>> (lambda x: x*2)(3) 
    6

    二.例子

    1.举例删除(没有对比就没有伤害)

    清楚列表l,只留元素4 (遍历删除元素一定要小心)

     1 l=[1,2,3,4]
     2 for i in l:
     3     if i != 4:
     4         l.remove(i)
     5 print(l)
     6 
     7 
     8 
     9 
    10 
    11 [2, 4]
    1 l=[1,2,3,4]
    2 for i in range(len(l)):
    3     if l[i] == 4:
    4         del l[i]
    5 print(l)
    6 
    7 
    8 [1, 2, 3]


    l=[1,2,3,4,5]
    for i in range(len(l)):
    if l[i] == 4:
    del l[i]
    print(l)


    ##会报错
    如果还是按照上面的方法,设想一下,range开始的范围是0-4,中间遍历的时候删除了一个元素4,这个时候列表变成了= [1,2,3,5],这时候就会报错了,提示下标超出了数组的表示,
    原因就是上面说的遍历的时候删除了元素



    l=[1,2,3,4,5]
    l = [i for i in l if i !=4]
    print(l)
    
    
    [1, 2, 3, 5]                         #产生一个新序列,赋值给l
    

     

    或者干脆建立新的list存放要删除的元素

    l=[1,2,3,4,5]
    dellsit = []
    for i in l:
        if i == 4:
            dellsit.append(i)
    for i in dellsit:
        l.remove(i)
    
    print(l)
    
    
    
    
    
    [1, 2, 3, 5]
    

      

    2.lambda 干了!

    salaries={
        'egon':3000,
        'alex':100000000,
        'wupeiqi':10000,
        'yuanhao':2000
    }
    print(max(salaries))    #默认取的ASICC码大的
    print(max(salaries.values()))
    def get_value(k):
        return salaries[k]
    print(max(salaries))
    print(max(salaries,key=get_value))
    i=iter(salaries)
    print(next(i))          #随机取的
    print(next(i))
    print(next(i))
    
    
    
    yuanhao
    100000000
    yuanhao
    alex
    egon
    alex
    wupeiqi
    yuanhao
    

      

     1 f=lambda k:salaries[k]
     2 print(f)
     3 print(f('egon'))
     4 print(max(salaries,key=lambda  k:salaries[k]))    ##自带return功能
     5 print(min(salaries,key=lambda k:salaries[k]))
     6 
     7 
     8 
     9 
    10 
    11 <function <lambda> at 0x000000000075E1E0>
    12 3000
    13 alex
    14 yuanhao

    3. zip拉链

     1 zip()
     2 l1=[1,2,3]
     3 s='hel'
     4 for i in zip(l1,s):         ##zip后面跟这两个加入字符类型,加入时字典中键值会自动加入
     5     print(i)
     6 
     7 
     8 
     9 
    10 (1, 'h')
    11 (2, 'e')
    12 (3, 'l')
    zip()
    l1=[1,2,3]
    s='hel'
    
    print(salaries.keys(),salaries.values())
    z=zip(salaries.values(),salaries.keys())
    print(z)
    # for i in z:
    #     print(i)
    print(max(z))
    print(max((1,'a'),(1,'b')))                   ##根据第一个值比较大小
    
    
    
    
    dict_keys(['yuanhao', 'wupeiqi', 'egon', 'alex']) dict_values([2000, 10000, 3000, 100000000])
    <zip object at 0x0000000000A575C8>
    (100000000, 'alex')
    (1, 'b')
    

      

    4.sorted   

     1 l=[3,2,5,23,44,4]
     2 print(sorted(l))               #返回值是列表,默认是升序
     3 print(sorted(l,reverse=True))       #降序
     4 
     5 s='hello abc'
     6 print(sorted(s))          #空格在最前面
     7 
     8 
     9 
    10 
    11 
    12 
    13 
    14 
    15 [2, 3, 4, 5, 23, 44]
    16 [44, 23, 5, 4, 3, 2]
    17 [' ', 'a', 'b', 'c', 'e', 'h', 'l', 'l', 'o']
     1 salaries={
     2     'egon':3000,
     3     'alex':100000000,
     4     'wupeiqi':10000,
     5     'yuanhao':2000
     6 }
     7 
     8 print(sorted(salaries))
     9 print(sorted(salaries,key=lambda  x:salaries[x]))         
    10 print(sorted(salaries,key=lambda x:salaries[x],reverse=True))   ##取反
    11 
    12 
    13 
    14 ['alex', 'egon', 'wupeiqi', 'yuanhao']
    15 ['yuanhao', 'egon', 'wupeiqi', 'alex']
    16 ['alex', 'wupeiqi', 'egon', 'yuanhao']

    5.map  映射

    m=map(lambda item:item**2,1)

    name_l=['alex','zhejiangF4','yuanhao']
    m=map(lambda name:name+'SB',name_l)      ##可迭代参数放到最后
    print(list(m))
    
    
    
    
    
    ['alexSB', 'zhejiangF4SB', 'yuanhaoSB']
    

    6.reduce    合并

    from functools import reduce
    l=list(range(100))
    print(l)
    print(reduce(lambda x,y:x+y,l,100))      ##后面还可以加初始值
    
    
    
    
    
    
    [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99]
    5050
    

      

    7.filter 过滤器

    name_l=[
        {'name':'egon','age':18},
        {'name':'dragonFire','age':1000},
        {'name':'gaoluchuan','age':9000},
        {'name':'fsw','age':10000},
    ]
    
    f=filter(lambda d:d['age'] > 100,name_l)            ##后面变成一个迭代器,next传给左边函数   这构成了一个返回值True的时候才传给下面
    print(f)
    for i in f:
        print(i)
    #用filter来处理,得到股票价格大于20的股票名字
    shares={
    'IBM':36.6,
    'Lenovo':23.2,
    'oldboy':21.2,
    'ocean':10.2,
    }

    f=filter(lambda x:shares[x] > 30,shares)
    print(f)
    for i in f:
    print(i)
    <filter object at 0x00000000006B17F0> {'age': 1000, 'name': 'dragonFire'} {'age': 9000, 'name': 'gaoluchuan'} {'age': 10000, 'name': 'fsw'}

      

    <filter object at 0x0000000000B61C88>
    IBM

    slice 

    l=[1,2,3,4,5,6,7,8]
    print(l[2:4])
    s=slice(2,4)
    print(l[s])
    print(l[2:5:2])    ##后面为步长
    print(l[::-1])
    print(l[::-2])
    
    
    
    
    
    
    
    
    
    [3, 4]
    [3, 4]
    [3, 5]
    [8, 7, 6, 5, 4, 3, 2, 1]
    [8, 6, 4, 2]
    

      

        

    三.注意

    1.这是一个 lambda 函数,完成同上面普通函数相同的事情。注意这里的简短的语法:在参数列表周围没有括号,而且忽略了 return 关键字 (隐含存在,因为整个函数只有一行)。而且,该函数没有函数名称,但是可以将它赋值给一个变量进行调用。


    2.使用 lambda 函数时甚至不需要将它赋值给一个变量。这可能不是世上最有用的东西,它只是展示了 lambda 函数只是一个内联函数。

    3.总的来说,lambda 函数可以接收任意多个参数 (包括可选参数) 并且返回单个表达式的值。lambda 函数不能包含命令,包含的表达式不能超过一个。不要试图向 lambda 函数中塞入太多的东西;如果你需要更复杂的东西,应该定义一个普通函数,然后想让它多长就多长。

    4.注意
    lambda 函数是一种风格问题。不一定非要使用它们;任何能够使用它们的地方,都可以定义一个单独的普通函数来进行替换。我将它们用在需要封装特殊的、非重用代码上,避免令我的代码充斥着大量单行函数。

















































































    ---恢复内容结束---

  • 相关阅读:
    HTML学习笔记之二(回到顶部 与 回究竟部)
    初次使用cocoapods注意事项
    struts2在web.xml中配置详情
    hdu 3631 Shortest Path(Floyd)
    bullet HashMap 内存紧密的哈希表
    论文摘抄
    oracle中从指定日期中获取月份或者部分数据
    漫谈机器学习经典算法—特征提取与特征选择
    为什么NULL能多次free
    栈的效率为什么比堆高?
  • 原文地址:https://www.cnblogs.com/jiangshitong/p/6704442.html
Copyright © 2011-2022 走看看