• 函数进阶(一)


    1.命名空间

    本质:存放名字与值的绑定关系

    命名空间的分类:可以分为三类

    (1)全局命名空间(变量)

    (2)局部命名空间(变量)

    (3)内置命名空间 (变量)->python解释器自带,拿过来就可以用的方法。

    三种命名空间的加载与取值顺序:

    加载顺序:内置命名空间(程序运行前加载)->全局命名空间(程序运行中,从上到下加载)->局部命名空间(程序运行时,调用时加载)

    取值:

    在局部调用:局部命名空间->全局命名空间->内置命名空间

    在局部使用变量取值的方法如下:

    a=1
    def f(a)
          print(a)
    
    print(10)
    在局部使用变量取值

    在全局调用:全局命名空间->内置命名空间

    ps:在全局引用变量x

    x=1
    def func(x):
          print(x)
    
    f(10)
    print(x)
    print(max)
    在全局使用内置max

    2.作用域

     定义:作用域就是作用范围,分为全局作用域(locals)和局部作用域(global)。

    全局作用域:包含内置名称空间、全局名称空间,在整个文件的任意位置都能被引用、全局有效

    局部作用域:局部名称空间,只能在局部范围内生效

    补充:

    #小范围的可以用大范围的,但是大范围的不能用小范围的

    #范围从大到小

    #在小范围内,如果要用一个变量,是当前这个小范围有的,就用自己的;如果在小范围内没有,就用上一级的,如果上一级没有,就用上上级的,如果都没有,则报错。

    3.函数嵌套

    函数嵌套(支持多层嵌套、多层并行):
    (1)格式:def 外部函数名():
    def 内部函数名1():
    def 内部函数名2():
    return 内部函数名1
    return 内部函数名2

    函数嵌套调用

    例一:
    name='alex'
    
    def foo():
        name='lhf'
        def bar():
            print(name)
        return bar
    
    func=foo()
    func()
    
    
    例二:
    name='alex'
    
    def foo():
        name='lhf'
        def bar():
            name='wupeiqi'
            def tt():
                print(name)
            return tt
        return bar
    
    func=foo()
    func()()
    View Code

    (2)调用:在函数内部,可以调用其他函数。如果在调用一个函数的过程中直接或间接调用自身本身
      定义一个函数只给了函数一个名称,指定了函数里包含的参数,和代码块结构。这个函数的基本结构完成以后,你可以通过另一个函数调用执行,也可以直接从Python提示符执行。

    函数的嵌套定义

    def f1():
        print("in f1")
        def f2():
            print("in f2")
    
        f2()
    f1()
    定义一
    def f1():
        def f2():
            def f3():
                print("in f3")
            print("in f2")
            f3()
        print("in f1")
        f2()
        
    f1()
    定义二

    闭包函数(可以有多级包):
    基础:闭包函数基于嵌套函数(闭包函数属于嵌套函数的一种)
    产生条件:
    a.必须为内部函数
    b.对外部作用域的引用(外部作用域不包括全局作用域,只限于在本层函数之外最外层函数之内的作用空间)
    特点:
    a.延迟计算(惰性计算,不调用不计算)
    b.自带作用域(作用域范围:本层函数之外全局作用域之内)

    ps:
    print(闭包函数的引用.__closure__)
    访问闭包函数的元素(闭包函数的引用.__closure__[0].cell_contents)

    def func():
        name = 'eva'
        def inner():
            print(name)
    闭包
    def func():
        name = 'eva'
        def inner():
            print(name)
        return inner
    
    f = func()
    f()
    闭包函数常用方法
    #输出的__closure__有cell元素 :是闭包函数
    def func():
        name = 'eva'
        def inner():
            print(name)
        print(inner.__closure__)
        return inner
    
    f = func()
    f()
    
    #输出的__closure__为None :不是闭包函数
    name = 'egon'
    def func2():
        def inner():
            print(name)
        print(inner.__closure__)
        return inner
    
    f2 = func2()
    f2()
    判断闭包函数的方法__closure__

    两个关键字:
    用法:关键字(global nonlocal) 变量名
    变量名 = 新的变量值
    global 全局声明,可以在函数内部将全局变量进行修改
    nonlocal 函数内部声明,可以在函数内部对局部变量进行修改(只能是内层函数对本层函数之外最外层函数之内的作用域变量进行修改)

    nonlocal关键字

    # 1.外部必须有这个变量
    # 2.在内部函数声明nonlocal变量之前不能再出现同名变量
    # 3.内部修改这个变量如果想在外部有这个变量的第一层函数中生效

    补充
    三目运算符:
    res = if成立时的结果 if 条件 else else成立时的结果

    练习题

    1、整理今天的知识点、继续整合思维导图

    2、写函数,,用户传入修改的文件名,与要修改的内容,执行函数,完成整个文件的批量修改操作

    import os
    def file_1(demo,i,j):
        with open(demo,'r',encoding='utf-8') as read_f,
              open('demo1.py','w',encoding='utf-8') as write_f:
            for line in read_f:
                write_f.write(line.replace(i,j))
        return read_f,write_f
    file_11,file_l2=file_1('demo.py','def','haha')
    os.remove(file_1.name)
    os.rename(file_l2.name,file_11.name)

    3、写函数,检查用户传入的对象(字符串、列表、元组)的每一个元素是否含有空内容。

    def func1(s):
        for i in s:
            if i.isspace():
                return False
            else:
                return True
    s='hello world'
    print(func1(s))

    4、写函数,检查传入字典的每一个value的长度,如果大于2,那么仅保留前两个长度的内容,并将新内容返回给调用者。
    dic = {"k1": "v1v1", "k2": [11,22,33,44]}
    PS:字典中的value只能是字符串或列表

    #方法一
    dic = {"k1": "v1v1", "k2": [11,22,33,44]}
    def length(s):
        a=[]
        for i in dic:
            if len(dic[i])>2:
             a.append({i:dic[i][0:2]})
        return a
    print(length(dic))
    #方法二
    dic = {"k1": "v1v1", "k2": [11,22,33,44]}
    def func1(dic):
        for i in dic:
            if len(dic[i])>2:
                dic[i]=dic[i][0:2]
        return dic
    print(func1(dic))
  • 相关阅读:
    Monitor All SQL Queries in MySQL (alias mysql profiler)
    to config RBS/RBLOB in sharepoint
    Chapter 10 EF 6 Support
    分布式网站架构后续:zookeeper技术浅析
    js中的json对象详细介绍
    JS通用方法总结(一)
    combobox远程加载数据的总结和Json数据的小结
    iframe自适应方法
    简单理解Hibernate三种状态的概念及互相转化
    hibernate的save()和persit()之间的区别
  • 原文地址:https://www.cnblogs.com/moning/p/7240746.html
Copyright © 2020-2023  润新知