一、变量

那些曾经怎么也看不懂的东西,突然有一天就懂了。这就是复习的力量吗?

1 变量的赋值

a = 10

做了上面的图所描述的事情

1)开辟一块内存,创建一个值为10的整数

2)创建一个a的标记

3)把a 指向内存中的值

关于堆和栈就先不考虑了,好吧。我自己不懂

再来一个难点的

a = 10
b = a
a = 20

这个够难了吧。你认为b是多少,是20吗,好吧。开始我也认为是20。但是b其实是10

很明显这张图是错误的。b不是指向了a,而是指向了10

  因为变量是一个标记,用来调用内存中的值,当我们将一个标记赋值给另一个标记的时候,应该是让其指向另一个标记的内存,而不是指向标记。

这张图才是正确的。b是指向了a指向的内存中的10,所以b是10

好了,变量赋值就到这里了

参考:https://www.cnblogs.com/scolia/p/5523883.html

好吧,我承认了,我只是复习我自己觉得模糊的东西,但是如果恰好你也对这些比较模糊,那咱俩还是挺有缘分的。如果你还对以外的东西比较模糊,那我只能说请移步到谷歌啥的

二 for中的迭代器和生成器

1 基础

a = (1, 2, 3, 4, 5)
for x in a:
print x

  

参考http://www.cnblogs.com/scolia/p/5538666.html

不得不说上面的这哥们真是个好人。

for循环其实就是不断的去可迭代对象中拿去元素,而可迭代对象在每次迭代的时候都会把指针下移一格,也就是下次再来拿的时候,拿的是下一个。而这是因为可迭代对象有这样行为,才称其为可迭代。

  这个时候我又要问一个问题,在迭代循环结束以后,x的值是否还存在?

  当然还在,都说了作用域是函数的东西,迭代循环并不是函数。按照for循环的思路,x的值是不断更新的,所以在循环结束的时候,x应该等于最后一次迭代的值。以这里为例,x在循环结束的时候,其值应该为5。即x=5。

 

a = (1, 2, 3, 4, 5)
for x in a:
print x
print '----',x
print a

  另外,虽说交租是交了出去自己没有了,但是迭代循环并不会改变a本身,也就是相当于借给别人看一眼,东西还是自己的。就想是以前的租碟吧哈哈

2)迭代器

  迭代器是一个实现了迭代器协议的对象,Python中的迭代器协议就是有next方法的对象会前进到下一结果,而在一系列结果的末尾是,则会引发StopIteration。

   而在for循环中,会自动调用 iter()将我们要迭代的对象转化为可迭代对象,每次循环都会调用 .next() 方法获取新元素,当引发StopIteration错误的时候自动退出循环,这就for循环的内部操作。

  常用的数据类型,如:str、tuple、list、dict、set,都能进行迭代循环,因为其内部都有相应的方法

上面的例子可以看到a属于可迭代的对象,但是可迭代对象仍然没有next方法,必须使用iter转换为迭代器才有

我们自己也可以创建一个可迭代的类:

# coding:utf-8
# author:wanstack class Text(object):
def __init__(self,list_input):
"""
实现一个迭代器
:param list_input:
"""
self.list = list_input # 你输入的可迭代对象,例如列表,元组,集合等
self.index = 0 # 索引从0开始 def __iter__(self):
return self # 这里返回的是一个Text类的对象,不是很清楚为什么加上这个就从可迭代对象就变成了迭代器 def next(self):
if self.index >= len(self.list): # 这个应该不可能大于,应该是等于,不过这里应该不影响,索引到了最后
self.index = 0 # 将索引置为0
raise StopIteration # 触发异常 ret = self.list[self.index] # 取出元素中的值
self.index += 1 # 索引往后移动一位
return ret # 返回元素中的值 a = Text([1,2,3])
for i in a:
print(i)

  

这里python3中会报错,python2没问题。

下面是python3的版本,可以看一下差别,好吧。基本没啥差别,就是把next换成了__next__,好无奈

# coding:utf-8
# author:wanstack class Text(object):
def __init__(self,list_input):
"""
实现一个迭代器
:param list_input:
"""
self.list = list_input # 你输入的可迭代对象,例如列表,元组,集合等
self.index = 0 # 索引从0开始 def __iter__(self):
return self # 这里返回的是一个Text类的对象,不是很清楚为什么加上这个就从可迭代对象就变成了迭代器 def __next__(self):
if self.index >= len(self.list): # 这个应该不可能大于,应该是等于,不过这里应该不影响,索引到了最后
self.index = 0 # 将索引置为0
raise StopIteration # 触发异常 ret = self.list[self.index] # 取出元素中的值
self.index += 1 # 索引往后移动一位
return ret # 返回元素中的值 a = Text([1,2,3])
for i in a:
print(i)

  

3)生成器

  所谓的生成器就是每次调用的时候返回一个对象,而不是一次性在内存中创建,从而达到节约内存的作用。

  而生成器靠yield关键字实现,生成器的编写类似于函数,只不过将函数的return改成了yield:

好吧,我对yield也忘记的差不多了。关于生成器请移步这里吧。http://www.cnblogs.com/wanstack/articles/6993620.html

三 深浅拷贝

先来看一个现象

1)浅拷贝

上面修改b的值,a的值一样会变化。为什么呢?

首先序列中保存的都是内存的引用,b是浅拷贝了a,所以a和b引用了同一个内存中的对象。所以,当我们通过b去修改里面的空列表的时候,其实就是修改内存中的同一个对象,所以会影响到a。

地址是一样的啊。所以虽然a和b是两个不同的对象,但是里面的引用都是一样的。这就是所谓新的对象,旧的内容。

但是下面的东西呢?

a = ['scolia', 123, [], ]
b = a[:]
b[1] = 666
print a
print b

对于字符串、数字等不可变的数据类型,修改就相当于重新赋值。在这里就相当于刷新引用。

a = ['scolia', 123, [], ]
b = a[:]
b[1] = 666
print id(a), id(a[0]), id(a[1]), id(a[2])
print id(b), id(b[0]), id(b[1]), id(b[2])

上面讲的这些就是浅拷贝,总结起来,浅拷贝只是拷贝了一系列引用,当我们在拷贝出来的对象对可修改的数据类型进行修改的时候,并没有改变引用,所以会影响原对象。而对不可修改的对象进行修改的是,则是新建了对象,刷新了引用,所以和原对象的引用不同,结果也就不同。

创建浅拷贝的方法:

  1.切片操作

  2.使用list()工厂函数新建对象。( b = list(a)

  3.使用copy模块的copy()方法。( b = copy.copy(a) )

2)深拷贝

  那么深拷贝不就是将里面引用的对象重新创建了一遍并生成了一个新的一系列引用。

  基本上是这样的,但是对于字符串、数字等不可修改的对象来说,重新创建一份似乎有点浪费内存,反正你到时要修改的时候都是新建对象,刷新引用的。所以还用原来的引用也无所谓,还能达到节省内存的目的。

from copy import deepcopy
a = ['scolia', 123, [], ]
b = deepcopy(a)
b[1] = 666
print id(a), id(a[0]), id(a[1]), id(a[2])
print id(b), id(b[0]), id(b[1]), id(b[2])

四 编码问题

请移步  http://www.cnblogs.com/wanstack/articles/7147683.html

关于文件的编码问题参考:http://www.cnblogs.com/scolia/p/5557839.html

五 装饰器

终于到装饰器了

参考这个吧。 http://www.cnblogs.com/wanstack/articles/6973057.html

我要复习python啦(一)的更多相关文章

  1. 复习python(条件判断、循环、字符串格式化)

    1.条件判断: 只有一种 if: *** elif:#多个条件加elif,想加几个加几个 **** else: **** python里靠缩进来表示表示语句块,见到冒号,下行就要缩进 2.循环 两种, ...

  2. 复习python

    1当命令行键入python a.py的方式运行python程序时候,a.py不需要执行权,当已./a.py运行时,需要执行权 2.与c语言不同的地方 i = 3 print (i)#合法 #在pyth ...

  3. 复习python的多态,类的内部权限调用 整理

    #多态的用法 class Dii: passclass Aii(Dii): def run(self): print('一号函数已调用')class Bii(Dii): def run(Dii): p ...

  4. 复习python的__call__ __str__ __repr__ __getattr__函数 整理

    class Www: def __init__(self,name): self.name=name def __str__(self): return '名称 %s'%self.name #__re ...

  5. [0x01 用Python讲解数据结构与算法] 关于数据结构和算法还有编程

    忍耐和坚持虽是痛苦的事情,但却能渐渐地为你带来好处. ——奥维德 一.学习目标 · 回顾在计算机科学.编程和问题解决过程中的基本知识: · 理解“抽象”在问题解决过程中的重要作用: · 理解并实现抽象 ...

  6. python之lambda函数

    今天复习python,看见一个关于lambda函数的例子,在python中使用lambda在某些时候十分方便,因为不必为了实现某些简单功能而新建一个函数.但是有这么一个lambda实例令我有些疑惑,现 ...

  7. 2018-06-20 中文代码示例视频演示Python入门教程第三章 简介Python

    知乎原链 Python 3.6.5官方入门教程中示例代码汉化后演示 对应在线文档: 3. An Informal Introduction to Python 不知如何合集, 请指教. 中文代码示例P ...

  8. python导入csv文件出现SyntaxError问题分析

    python导入csv文件出现SyntaxError问题分析 先简单描述下碰到的题目,要求是写出2个print的结果 可以看到,a指向了一个列表list对象,在Python中,这样的赋值语句,其实内部 ...

  9. 重拾python所要知道的一些主干知识点

    前言:因为有一段时间没有用python了,最近需要用到,只能回头过去看B站视频补一补,因为语言都是相通的,而且一些细节都可以去查表解决,所以呢,我们只需要知道一些python与其他语言的不同和常见的优 ...

随机推荐

  1. zen-cart 一页支付实现方法

    1.下载插件CSS JS Loader 和 Fast and Easy Checkout for Zen Cart,插件请下载附件 2.先把CSS JS Loader覆盖,后台选项点击,点击后,程序会 ...

  2. NodeJS NPM HTTPS

    npm config set registry http://registry.npmjs.org/

  3. C++与C混编

    C++与C混编 本案例通过实现一个简单的UDP服务器来说明C++与C的混合编程问题 C代码 通过C代码来对UDP服务器的创建,监听进行封装 udp.c文件 #include <sys/types ...

  4. kdump+crash

    参考:http://www.360doc.com/content/19/0205/08/36367108_813163495.shtml https://blog.csdn.net/u01436103 ...

  5. jquery试题

    1.下面哪种说法是正确的? 您的回答:jQuery 是 JavaScript 库 2.jQuery 使用 CSS 选择器来选取元素? 您的回答:正确 3.jQuery 的简写是? 您的回答:$ 符号 ...

  6. 在python3下使用OpenCV 抓取摄像头图像提取蓝色

    工作中需要对摄像头进行调试, Python平台大大提高调试效率. 从网找到段代码, 可以从摄像头图像中抠出蓝色. import cv2 import numpy as np cap  = cv2.Vi ...

  7. CSS Pseudo-classes(伪类)

    CSS Pseudo-classes(伪类) CSS伪类是用来添加一些选择器的特殊效果. 一.语法 伪类的语法: selector:pseudo-class {property:value;} CSS ...

  8. cordova 插件

    1.移动端WebApp开发,如何实现状态栏沉浸式效果? cordova-plugin-fullscreen 2. cordova热更新插件-不发布应用市场动态更新APP源码 https://githu ...

  9. go channel 阻塞

    初接触 go 有不对得请解释下 Channel是goroutine之间进行通信的一种方式,先看下面代码为什么会阻塞: func closer(ch chan int) { ch <- 1 log ...

  10. saltstack实现自动化扩容

    案例:当nginx的并发达到3000,并持续了一段时间时,通过自动化创建一台虚拟机,部署应用最后添加到集群提供服务: zabbix监控(nginx并发量)------->action------ ...