zoukankan      html  css  js  c++  java
  • python学习Day12--函数名的使用

    【主要内容】

    1, 函数名的应用,第一类对象
    函数名可以像变量一样进行使用
    1.赋值
    2.作为list元素
    3.作为参数
    4.作为返回值

    2, 闭包
    内部函数访问外部函数的局部变量.
    好处:
    1.安全
    2.常驻内存. 提高效率
    3, 迭代器
    可迭代对象(Iterable):内部包含__iter__().
    迭代器(Iterator): 内部含有__iter__() __next__()
    str, list, tuple, set, dict
    f, range

    迭代器的特点:
    1.省内存
    2.惰性机制
    3.只能向前.

    【代码】

    1.函数名的应用

     1 # def func():
     2 #     print("你吃了么?")
     3 #
     4 # # print(func)
     5 # # a = func    # 函数名就是一个变量
     6 # # print(a)
     7 # # func()
     8 # # a() # 就是一个函数的调用
     9 #
    10 # def a():
    11 #     print("我吃了")
    12 #
    13 # func = a
    14 # func()
    15 
    16 # a = 8
    17 # b = 7
    18 # c = 1
    19 # d = 3
    20 # lst = [a, b , c, d]
    21 # print(lst)
    22 #
    23 # def f1():
    24 #     print("我是马化腾")
    25 # def f2():
    26 #     print("我是马云")
    27 # def f3():
    28 #     print("我是马赛克")
    29 # def f4():
    30 #     print("我是马蔚华")
    31 #
    32 # lst = [f1(), f2(), f3(), f4()]
    33 # print(lst)
    34 
    35 
    36 # 还可以作为函数的参数
    37 # def func(food):
    38 #     print("吃", food)
    39 #
    40 # a = "火锅"
    41 # func(a)
    42 
    43 
    44 # def func(fn):
    45 #     fn()
    46 #
    47 # def gn():
    48 #     print("我是火锅, 刚才有人要吃我")
    49 # func(gn)    # 可以把函数作为参数, 传递给另一个函数
    50 
    51 
    52 # def func():
    53 #     def inner():
    54 #         print("火锅不让吃了. 吃了上火")
    55 #     return inner
    56 # ret = func()    # 这里func()执行之后获取到的是inner函数
    57 # ret()   # 这里是让inner函数执行
    58 
    59 # 综上. 函数就是一个变量

    2、闭包

    # name = "wusir"  # 变量写在全局是不安全的
    #
    # def abc():
    #     global name
    #     name ="呵呵"
    # abc()
    #
    # def func():
    #     name = "alex"   # 常驻内存  防止其他程序改变这个变量
    #     def inner():
    #         print(name) # 在内层函数中调用了外层函数的变量,叫闭包, 可以让一个局部变量常驻内存
    #     return inner
    #
    #
    # ret = func()
    # ret() # 执行的是inner()
    # ret()
    # ret()
    # ret()
    # ret()
    
    # 闭包的好处
    from urllib.request import urlopen
    def but():
        content = urlopen("http://www.h3c.com/cn/").read()
        def inner():
            print("你好啊")
             # return content # 在函数内部使用了外部的变量 . 闭包
        print(inner.__closure__)    # 查看inner是否是闭包, 如果有东西就是闭包, 没东西就不是闭包
        return inner
    print("加载中........")
    fn = but()  # 这个时候就开始加载校花100 的内容
    # 后⾯需要⽤到这⾥⾯的内容就不需要在执⾏⾮常耗时的⽹络连接操作了
    content = fn()   # 获取内容
    print(content)
    content2 = fn()  # 重新获取内容
    print(content2)

    3、迭代器

    # s = "北京欢迎您"
    # for c in s:
    #     print(c)
    
    # for i in 123:
    #     print(i)
    # 可迭代对象: str, list, tuple, set, f, dict
    # 所有的以上数据类型中都有一个函数__iter__(), 所有包含了__iter__()的数据类型都是可迭代的数据类型 Iterable
    # dir()来查看一个对象,数据类型中包含了哪些东西
    # lst = [1,2,3]   # list
    # # print(dir(lst))
    # s = "王尼玛"
    # print("__iter__" in dir(s))
    # print("__iter__" in dir(lst))
    # print("__iter__" in dir(123))
    
    # list是一个Iterable.可迭代的
    # lst = ["皇阿玛", "皇额娘", "容嬷嬷", "紫薇"]
    # 获取迭代器
    # it = lst.__iter__()
    # # 迭代器往外拿元素. __next__()
    # print(it.__next__())    # 皇阿玛
    # print(it.__next__())    # 皇额娘
    # print(it.__next__())    # 容嬷嬷
    # print(it.__next__())    # 紫薇
    # print(it.__next__())    # 迭代到最后一个元素之后. 再进行迭代就报错了
    
    # lst = ["皇阿玛", "皇额娘", "容嬷嬷", "紫薇"]
    # # 模拟for循环
    # it = lst.__iter__()
    # while True:
    #     try:
    #         name = it.__next__()
    #         print(name)
    #     except StopIteration: # 拿完了
    #         break
    
    lst = [1, 2, 3]
    from collections import Iterable    # 可迭代的
    from collections import Iterator    # 迭代器
    
    # isinstence(对象, 类型) 判断xx对象是否是xxx类型的
    # print(isinstance(lst, Iterable))
    # print(isinstance(lst, Iterator))
    
    # it = lst.__iter__()
    # print(isinstance(it, Iterable)) # 判断是否是可迭代的 迭代器一定是可迭代的
    # print(isinstance(it, Iterator)) # 迭代器里面一定有__next__(), __iter__()
    
    # print("__iter__" in dir(lst))   # 确定是一个可迭代的
    # print("__next__" in dir(lst))   # 确定不是一个迭代器
    
    # f = open("01 今日内容大纲",mode="r", encoding="utf-8")
    # print(isinstance(f, Iterable))
    # print(isinstance(f, Iterator))
    
    # 迭代器的特点:
    #   1. 节省内存
    #   2. 惰性机制
    #   3. 只能往前拿. 不能反着拿
    lst = ["哈哈", "呵呵"]
    it = lst.__iter__()
    it.__next__()
    print(it.__next__())
    print("我要吃黄瓜")
    print(it.__next__())

    4、作业与练习

     1 '''
     2 #****************作业讲解******************
     3 # 接收n个参数,返回最大值和最小值(字典)
     4 def func(*args):
     5     max=args[0]
     6     min=args[0]
     7     for el in args:
     8         if el > max:
     9             max=el
    10         if el < min:
    11             min=el
    12     return {'最大值':max,'最小值':min}
    13 print(func(1,56,34,78,34,56,90,12,45))
    14 
    15 #一个需要注意的坑
    16 def extendList(val,list=[]):
    17     list.append(val)
    18     return list
    19 list1=extendList(10)
    20 list2=extendList(123,[])
    21 list3=extendList('a')
    22 print(list1)    # [10, 'a']   因为list3调用了最开始默认的列表
    23 print(list2)    # [123]
    24 print(list3)    # [10, 'a']
    25 
    26 # 99乘法表
    27 a=1
    28 while a < 9:
    29     b=1
    30     while b <= a:
    31         print("%dx%d=%d	" % (a,b,a*b),end="")  #每次打印都换行了,end=""消除每行换行的问题
    32         b = b + 1
    33     print()  #换行,()空——默认换行
    34     a= a + 1
    35 '''
    36 
    37 #**************今日练习*****************
    38 '''
    39 # 函数就是一个变量
    40 def func():
    41     def inner():
    42         print("不让吃火锅了,吃了上火")
    43     return inner
    44 ret=func()
    45 ret()
    46 '''
    47 # while+迭代器模拟for循环
    48 lst=[1,2,3,4,5,6]
    49 it=lst.__iter__()
    50 while True:
    51     try:
    52         name=it.__next__()
    53         print(name)
    54     except StopIteration:
    55         break
  • 相关阅读:
    [转]22条经典的编程引言 朱燚:
    [转]Windbg的学习记录(一) 朱燚:
    C#7.0 模式匹配与if语句
    使用switch表达式简化switch语句
    .Net 5 在函数中使用Lambda
    MongoDB find getmore操作慢问题排查
    multikey索引和wildCard索引场景比较
    一个高性能跨平台基于Python的Waitress WSGI Server的介绍!
    郁闷的一天!
    互联网项目管理要点
  • 原文地址:https://www.cnblogs.com/fengxb1213/p/12290806.html
Copyright © 2011-2022 走看看