python学习之老男孩python全栈第九期_day010知识点总结
def qqxing(l = []): # 可变数据类型
l.append(1)
print(l)
qqxing() # [1]
qqxing([]) # [1]
qqxing() # [1, 1]
qqxing() # [1, 1, 1]
# 如果默认参数的值是一个可变数据类型,那么每一次调用函数的时候,如果不传值,就公用这个数据类型的资源
def qqxing(l = {}): # 可变数据类型
l['k'] = 'v'
print(l)
qqxing() # {'k': 'v'}
qqxing({}) # {'k': 'v'}
qqxing() # {'k': 'v'}
qqxing() # {'k': 'v'}
def qqxing(k, l = {}): # 可变数据类型
l[k] = 'v'
print(l)
qqxing(1) # {1: 'v'}
qqxing(2) # {1: 'v', 2: 'v'}
qqxing(3) # {1: 'v', 2: 'v', 3: 'v'}
qqxing(4) # {1: 'v', 2: 'v', 3: 'v', 4: 'v'}
# 函数进阶
# a = 1
# def func():
# print(a)
# func()
# def func(): # 报错
# a = 1
# func()
# print(a)
# 命名空间和作用域
# 命名空间:有三种
# 内置的命名空间 -- python解释器
# 就是python解释器一启动就可以使用的名字,存储在内置命名空间中(比如:print())
# 内置的名字在启动解释器的时候被加载进内存里
# 全局命名空间 -- 我们写的代码,但不是函数中的代码
# 是在程序从上到下被执行的过程中一次加载进内存的
# 放置了我们设置的所有变量名和函数名
# 局部命名空间 -- 函数
# 就是函数内部定义的名字
# 当调用函数的时候才会产生这个名称空间,随着函数执行的结束,这个命名空间就又消失了
# 在局部中,可以使用全局、内置命名空间中的名字
# 在全局中:可以使用内置命名空间中的名字,但是不能用局部中的名字
# 在内置中:不能使用局部和全局的名字的
#-------------------------------------------------------------------------------------#
# 当我们在全局定义了和内置命名空间中相同的名字, 会使用全局的名字
# 在正常情况下(全局没有定义),直接使用内置的名字
# 当我自己有的时候, 就不找上级要了;如果自己没有, 就一直找上一级要.若最后都没有就会报错
# 多个函数应该拥有多个独立的局部名字空间,不互相共享
# def input():
# print('in input now')
#
# def func():
# # input = 1
# print(input)
# input()
# func()
'''
func --> 函数的内存地址
func() --> 函数名(): 函数的调用
故 --> 函数的内存地址():函数的调用
'''
'''
def func():
a = 1
def func():
print(a)
只能从上级找,不能局部命名空间之间找
# 多个函数应该拥有多个独立的局部名字空间,不互相共享
'''
# 作用域:两种
# 全局作用域 --> 作用在全局 -- 内置和全局名字空间中的名字都属于全局作用域 -- globals()
# 局部作用域 --> 作用在局部 -- 函数(局部名字空间中的名字属于局部作用域) -- locals()
'''
对于不可变数据类型,在局部可以查看全局作用域中的变量,但是不能 直接 修改;
如果想要修改,需要在程序中的一开始添加global声明(尽量少使用)
如果在一个局部(函数)内声明了一个global变量,那么这个变量在局部的所有操作将对全局的变量有效
locals() 函数会以字典类型返回*当前位置*的全部局部变量
本地的:locals()放在局部就打印局部的全部变量,放在全局里就是打印全局的全部变量,这时等于globals()
a = 1
def func():
a += 1
print(a)
func()
-------------------------------------------------------------
a = 1
def func():
global a
a += 1
print(a)
func()
'''
#
# a = 1
# b = 2
# def func():
# x = 'xxx'
# y = 'yyy'
# print(locals())
# func()
# print(globals())
# globals()永远打印全局的名字
# locals():输出什么 会根据locals所在的位置
# def max(a,b):
# if a > b:
# return a
# else:
# return b
#
# def the_max(x,y,z): # 函数的嵌套调用
# c = max(x,y)
# return max(c,z)
# print(the_max(1,2,3))
# 函数的嵌套定义
# 内部函数可以使用外部函数的变量
# nonlocal 只能用于局部变量(对全局无效),找上层中离当前函数最近一层的局部变量(对局部也是对最近的一层有影响)
# 声明了nonlocal的内部函数的变量修改会影响到离当前函数最近一层的局部变量
# a = 5
# def outer():
# a = 1
# def inner():
# b = 2
# def inner2():
# # print(a, b)
# # global a # 声明一个全局变量(但这个地方的a是局部变量)
# nonlocal a # 声明一个上面第一层 局部 变量, 若所有局部变量都没有, 则报错
# a += 1 #报错, 不可变数据类型的修改
# print('inner2:', a)
# inner2() # 需要调用
# print('inner:',a)
# inner() # 需要调用
# print('outer:', a)
# outer()
# print('**a**:', a)
def func():
print(123)
# func() # 函数名就是内存地址
# func2 = func # 函数名可以赋值
# func2()
#
# l = [func, func2] # 函数名可以作为容器类型的元素
# print(l)
# for i in l:
# i()
# def wahaha(f):
# f()
# wahaha(func) # 函数名可以作为函数的参数
def wahaha(f):
f()
return f # 函数名可以作为函数的返回值
qqxing = wahaha(func) #
qqxing()
# def outer():
# a = 1
# def inner(): # inner()是一个闭包
# print(a)
# print(inner.__closure__) # (<cell at 0x0000027BBB57C828: int object at 0x00007FF9F9D7D420>,)
# # cell 说明inner()是闭包
# outer()
# print(outer.__closure__) # None 说明outer不是闭包
# 闭包:嵌套函数,且内部函数调用外部函数的变量
#
# def outer():
# a = 1
# def inner():
# print(a)
# return inner
# inn = outer()
# inn()
import urllib # 模块
from urllib.request import urlopen
# ret = urlopen('http://www.xiaohua100.cn/guowai/').read()
# print(ret)
# def get_url():
# ret = urlopen('http://www.xiaohua100.cn/guowai/').read()
# print(ret)
def get_url():
url = 'http://www.xiaohua100.cn/guowai/'
def inner():
res = urlopen(url).read()
print(res)
return inner
inn = get_url()
inn()
python学习之老男孩python全栈第九期_day010知识点总结的更多相关文章
- python学习之老男孩python全栈第九期_day027知识点总结——反射、类的内置方法
一. 反射 ''' # isinstance class A:pass class B(A):pass a = A() print(isinstance(a,A)) # 判断对象和类的关系 print ...
- python学习之老男孩python全栈第九期_day023知识点总结——类和对象命名空间、组合
一. 类和对象命名空间类里 可以定义两种属性: 1. 静态属性 2. 动态属性 class Course: language = 'Chinese' def __init__(self, teache ...
- python学习之老男孩python全栈第九期_day019知识点总结——collections模块、时间模块、random模块、os模块、sys模块
一. collections模块 在内置数据类型(dict.list.set.tuple)的基础上,collections模块还提供了几个额外的数据类型:namedtuple.deque.Counte ...
- python学习之老男孩python全栈第九期_day017知识点总结——初识递归、算法
一. 递归函数 如果一个函数在内部调用自身本身,这个函数就是递归函数. 最大递归深度默认是997 -- python从内存角度出发做得限制(而不是程序真的报错),最大深度可以修改 def func(n ...
- python学习之老男孩python全栈第九期_day007知识点总结
基础数据类型汇总 1. str 2. int 3. list 4. bool 5. dict (1) fromkeys Python 字典 fromkeys() 方法用于创建一个新的字典,并以可迭代对 ...
- python学习之老男孩python全栈第九期_day001知识点总结
1. Python2与Python3的区别: Python2:源码不标准,混乱,重复代码太多: Python3:统一标准,去除重复代码. 编码方式: python2的默认编码方式为ASCII码:pyt ...
- python学习之老男孩python全栈第九期_day014知识点总结
# 迭代器和生成器# 迭代器 # 双下方法:很少直接调用的方法,一般情况下,是通过其他语法触发的# 可迭代的 --> 可迭代协议:含有__iter__的方法( '__iter__' in dir ...
- python学习之老男孩python全栈第九期_day016知识点总结
'''数据类型:intbool... 数据结构:dict (python独有的)listtuple (pytho独有的)setstr''' # reverse() 反转l = [1,2,3,4,5]l ...
- python学习之老男孩python全栈第九期_day015知识点总结
# 作用域相关(2)locals() # 返回本地作用域中的所有名字 globals() # 返回全局作用域中的所有名字 # 迭代器/生成器相关(3)range()print('__next__' i ...
随机推荐
- Swift 里 Array (二)初始化
init() 函数 在 Array 里 public init() { _buffer = _Buffer() } 以Buffer 是 _ContiguousArrayBuffer 为例. 即初始化了 ...
- SQL高效查询两个表不同的数据
逻辑相对复杂,但是速度最快: )
- Liferay7 BPM门户开发之2: BPMN 2.0 规范入门 (Activiti BPMN extensions)
Liferay最大的问题是BPM弱,如果做企业开发,BPM必不可少,所以直入主题,做个BPMN2入门. 本文参考地址:http://activiti.org/userguide/index.html# ...
- 第四章 PCA降维
目录 1. PCA降维 PCA:主成分分析(Principe conponents Analysis) 2. 维度的概念 一般认为时间的一维,而空间的维度,众说纷纭.霍金认为空间是10维的. 3. 为 ...
- rabbitmq系列五 之远程过程调用(RPC)
1.远程过程调用(RPC) 在第二篇教程中我们介绍了如何使用工作队列(work queue)在多个工作者(woker)中间分发耗时的任务. 可是如果我们需要将一个函数运行在远程计算机上并且等待从那儿获 ...
- Python Web Server Gateway Interface -- WSGI
了解了HTTP协议和HTML文档,我们其实就明白了一个Web应用的本质就是: 浏览器发送一个HTTP请求: 服务器收到请求,生成一个HTML文档: 服务器把HTML文档作为HTTP响应的Body发送给 ...
- python使用(一)
1.hellopython.py 2.base_option.py 3.str_option.py 4.time_option.py hellopython.py # coding=utf8 __au ...
- (转)Python: super 没那么简单
原文:https://mozillazg.com/2016/12/python-super-is-not-as-simple-as-you-thought.html python 约定¶ 单继承¶ 多 ...
- Android_EditText 打勾显示输入的密码 --EditText与setTransformationMethod
实现目标: 实现原理: 为CheckBox添加一个监听器事件; 实现的源码: package edu.cquptzx.showPassword; import android.app.Activity ...
- XAML属性赋值转换之谜(WPF XAML语法解密)
XAML与XML类似,就是XML延伸过来的.为了更好的表达一些功能,WPF对XML做了扩展,有些功能是WPF在后台悄悄的替你做了.有时候,虽然实现了某个功能,但是对实现原理还是很茫然.今天就讲讲XAM ...