认知: 随着年龄阅历的变化而变化。
01 去年内容回顾
*args **kwargs: 万能参数,动态参数
* 魔性用法:
函数的定义时,* ** 聚合。
函数的执行时,* ** 打散。

形参顺序:
位置参数,*args,默认参数,**kwargs
名称空间:
临时名称空间:
内置名称空间:
作用域:
全局作用域:内置名称空间,全局名称空间。
局部作用域:临时名称空间(局部名称空间)。
加载顺序: 内置名称空间 全局名称空间 临时名称空间
取值顺序:就近原则,LEGB。
内置函数:
globals(): 返回一个字典:全局作用域的内容。
locals() : 返回一个字典:当前作用域的内容。
关键字:
global:
1,在局部作用域可以声明一个全局变量。
2,在局部作用域可以对全局变量进行修改。
nonlocal:
1,不能对全局变量进行修改。
2,子级对父级函数的变量的修改。

02 作业讲解
03 函数名的运用
04 闭包
05 迭代器

#03 函数名的运用

#1  函数名是一个特殊的变量# def func():#     print(666)# print(func)#2  函数名可以当做变量赋值# f1 = 2# f2 = f1# f3 = f2# print(f3)

# def func():#     print(333)# func1 = func# f2 = func1# f3 = f2# print(f3)# f3()

#3  函数名可以当做容器类数据类型的元素# def func1():#     print('in func1')## def func2():#     print('in func2')## def func3():#     print('in func3')## l1 = [func1,func2,func3]# for i in l1:#     i()

#4  函数名可以当做函数的参数# def func(x):#     print(x)#     x()#     print('in func')## def func1():#     print('in func1')## func(func1)

#5  函数名可以当做函数的返回值# def func(x):#     return x## def func1():#     print('in func1')## func(func1)()

#函数名也成为第一类对象

#04 闭包#闭包:    #1,内层函数对外层函数(非全局)变量的引用    #2,闭包只存在于内层函数中    #3,函数都要逐层返回,最终返回给最外层的函数

# 坑:引用也是闭包# n = 'mo'# def func(n):###n引用,相当于在里面执行 n = 'mo'

#不是闭包例子:# name = 'alex'# def func():#     def inner():#         print(name)#     return inner# f = func()# print(f.__closure__[0].cell_contents)   #??? /\

#闭包# def func():#     name = 'alex'#     age = 12#     def inner():#         print(age)#         print(name)#     return inner# f = func()#获取闭包引用的外层变量# print(f.__closure__[0].cell_contents)# print(f.__closure__[0].cell_contents)

# def func(n):#     def inner():#         print(n)#     return inner# name = '太白'# f = func(name)# print(f.__closure__[0].cell_contents)   #??? /\ f = func(name)

# def func(n):#     n = name#     def inner():#         print(n)#     return inner# name = '太白'# f = func(name)# print(f.__closure__[0].cell_contents)

#闭包有什么用???# def func(step):#     num = 1#     num += step#     print(num)# j = 0# while j < 5:#     func(3)#     j +=1 ##每次结果一样#闭包:解释器执行程序时,如果遇到函数,随着函数的结束而关闭临时命名空间,但是!!!#如果遇到闭包,有一个机制:那么闭包的空间不会随着函数的结束而关闭# def wrapper(step):        ###执行过程???#     num = 1#     def inner():#         nonlocal num#         num += step#         print(num)#     return inner# f = wrapper(3)# j = 0# while j < 5:#     j += 1#     f() #等同于inner()

#闭包的应用:#1  装饰器#2  爬虫

#05 迭代器#iterable:可迭代对象:#str list tuple set dic range() 文件句柄# for i in 'abcd':#     print(i)

# for i in 123:#     print(i)#报错:TypeError: 'int' object is not iterable

#可迭代对象:内部含有__iter__方法的就是可迭代对象,遵循可迭代协议s1 = 'barry'# l1 = [1,2,3]# print(dir(s1))#列出s1包含的所有方法

#判断一个对象是否是可迭代对象,迭代器#方法一:# print('__iter__' in dir(s1))# print('__iter__' in dir(range(10)))

#可迭代对象不能直接取值

#迭代器:内部含有'__iter__'并且含有'__next__'方法的就是迭代器,遵循迭代器协议

#可迭代对象转化成迭代器:#       可迭代对象.__iter__()或者iter(可迭代对象)#       obj = s1.__iter__()

# s1 = 'abcd'# obj = iter(s1)# print(obj)# print(obj.__next__())# print(obj.__next__())# print(obj.__next__())#逐个取出迭代器里的元素,一个next对应一个值,一一对应# print(dir(obj))# print('__iter__' in dir(obj) and '__next__' in dir(obj))

#方法二:# from collections import Iterable# from collections import Iterator# s1 = 'abcd'# obj = iter(s1)# print(isinstance(obj,Iterable))# print(isinstance(obj,Iterator))

# type()与isinstance()的区别:#type()只是判断该对象的数据类型#isinstance()不仅可以判断该对象的数据类型,而且可以判断其他很多from collections import Iterablefrom collections import Iterator# s1 = 'abcd'# print(isinstance(s1,str))# print(type(s1))

# 迭代器的作用:# 1,节省内存.# 2,惰性机制.# 3, 一条路走到黑,不走回头路.# s2 = [1, 2, 3, 4, 5]# obj2 = iter(s2)# print(next(obj2))# print(next(obj2))

# 练习# 判断一个对象是否是可迭代对象,迭代器# str list tuple set dict range() 文件句柄# f = open('file',encoding='utf-8',mode='w')# print(isinstance(f,Iterator))

# s2 = [1, 2, 3]# # 将s2转化成迭代器 进行取值# obj2 = iter(s2)# # print(obj2.__next__())# print(next(obj2))

#while 循环模拟 for 循环机制# l1 = [i for i in range(20)]# s1 = 'fsdhjkafjdsfalkdjsflksd;f'# obj = iter(s1)# while 1:#     try:#         print(next(obj))#     except StopIteration:#         break

day10_python_1124的更多相关文章

随机推荐

  1. return ajax 把ajax链式操作 简易封装

    成功就是done,失败就是fail

  2. Python基础学习之Python主要的数据分析工具总结

    Python主要是依靠众多的第三方库来增强它的数据处理能力的.常用的是Numpy库,Scipy库.Matplotlib库.Pandas库.Scikit-Learn库等. 常规版本的python需要在安 ...

  3. bootstrap-wysiwyg这个坑

    但是用wysiwyg也是费了我不少的精力,特别是在图片上传上,下面做一些总结. 1.引入文件 wysiwyg号称只有5kb,但是实际上是将其他的依赖文件在cdn上用外链链接进来了,有以下几个文件: c ...

  4. unittest改写传参方法

    Python主要讲究简洁简单使用,所以它不像junit一样支持参数化测试,需要改装一下也可以传参.直接上代码实例 import unittest class ParametrizedTestCase( ...

  5. Python记录11:叠加多个装饰器+有参装饰器

    # import time## def timmer(func): #func=最原始的index的内存地址# def wrapper(*args,**kwargs):# start=time.tim ...

  6. 3.Python3变量与基本数据类型

    3.1保留字和标识符 3.1.1保留字 保留字是Python语言中已经被赋予特定意义的一些单词,开发程序时不可以把保留字作为变量.函数.类.模块和其他对象的名称来使用.保留字如下: 3.1.2标识符 ...

  7. 玩转spring boot——war部署

    前言 之前部署spring boot应用是通过直接输入命令“java -jar”来实现的.而有些情况,由于部署环境的制约,只能把项目从jar转换成war才能部署,如新浪云sae的java环境容器.那怎 ...

  8. spring AOP自定义注解方式实现日志管理

    今天继续实现AOP,到这里我个人认为是最灵活,可扩展的方式了,就拿日志管理来说,用Spring AOP 自定义注解形式实现日志管理.废话不多说,直接开始!!! 关于配置我还是的再说一遍. 在appli ...

  9. DB2 错误代码

    sqlcode sqlstate 说明 000 00000 SQL语句成功完成 01xxx SQL语句成功完成,但是有警告 +012 01545 未限定的列名被解释为一个有相互关系的引用 +098 0 ...

  10. dotnet core命令

    dotnet run -----运行程序 dotnet publish -r centos-x64  -----发布程序 mkdri 文件名--->cd 文件名--->dotnet new ...