zoukankan      html  css  js  c++  java
  • Python从入门到精通之eighth!

    函数式编程与内置函数

    函数作用域:

    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() #不能调用字符类型模块




  • 相关阅读:
    codeforce1029B B. Creating the Contest(简单dp,简单版单调栈)
    spfa算法
    spfa算法
    HDU King (非连通图的差分约束,经典好题)
    HDU King (非连通图的差分约束,经典好题)
    差分约束系统相关证明(存在负环则无解证明)
    Java API 读取HDFS的单文件
    採用邻接矩阵创建图
    旧金山攻略
    一个jeecg整合activiti的学习样例,源代码下载
  • 原文地址:https://www.cnblogs.com/xtznb/p/10497697.html
Copyright © 2011-2022 走看看