一、高阶函数-排序

1.定义:把一个序列按照给定算法进行排序

2.key:在排序前对每一个元素进行key函数运算,可以理解成按照key函数定义的逻辑进行排序

3.python2和python3相差巨大

 

#help(sorted)

#排序案例1

a = [526,6,5565,323,596,265,6256]

#升序输出

al = sorted(a)

#降序输出

ap = sorted(a,reverse=True)

print(al)

print(ap)

​

#排序案例2

b = [514,56,25,526,-54,-54156,4,54,-415]

#按照绝对值排序

#abs是求绝对值的意思

a1 = sorted(b,key=abs,reverse=True)

print(a1)

​

#sorted案例

astr = ['dana','Dana','youxiu','asdhj']

a2 = sorted(astr)

print(a2)

a3 = sorted(astr,key=str.lower)

print(a3)

 

二、返回函数

1.函数也可以返回具体的值;也可以返回一个函数作为结果

2.我们接下来举例,只举第二段话的例子

 

def myF2():

    def myF3():

        print("再试一下结果")

        return 3

    return myF3

f3 = myF2()

print(type(f3))

print(f3)

print("------分割线------")

print(f3())

从返回值里面看出反回了一个类函数,然后我们运行了这个函数。

三、负责一点的返回函数的例子args:参数列表

​注:(1)myF4定义了函数,返回内部函数定义的myF5;(2)myF5定义了外部变量,这个变量是myF4的参数

 

def myF4(*args):

#*args中的星号是让Python创建一个名为args的空元组

    def myF5():

        rst = 0

        for n in args:

            rst += n

        return rst

    return myF5

f5 = myF4(2,8,54,652,6526,6)

print(f5())

对比一下

 

 

def myF6(*args):

    rst = 0

    for n in args:

        rst += n

    return rst

f6 = myF6(2,8,54,652,6526,6)

print(f6)

 

 

​总结:其实这个和上面函数得数一样,但是下面更好理解一些,这里就是为了做一个能够返回函数的演示,而且最本质的区别在于,一个是返回函数一个是返回值。

之所以要更复杂,是因为在企业的开发中返回函数更具有安全性要求,我们对函数可以进行加密​。​

四、源码:

d20_1_sorted_function&return_function_of_function

地址:https://github.com/ruigege66/Python_learning/blob/master/d20_1_sorted_function%26return_function_of_function

2.CSDN:https://blog.csdn.net/weixin_44630050(心悦君兮君不知-睿)

3.博客园:https://www.cnblogs.com/ruigege0000/

4.欢迎关注微信公众号:傅里叶变换,后台回复”礼包“,获取大数据学习资料。

 

posted on 2019-06-28 00:26  心悦君兮君不知-睿  阅读(371)  评论(0编辑  收藏  举报