Python缺乏调查的陷阱 动态实例属性、引用、逃生

——看到哪里。想到哪里,记到哪里

非常多时候。非常多人学python的时候,会忽略的东西非常多。大多数都盯着能“出货”即可,可是通常在读别人的代码的时候发现,看不懂。。。一方面是自己的代码技巧和经验不足;还有一方面就是自己掌握的东西不全面。而这些往往是基础的东西。还不算高大上的东西。。

第一:动态实例属性

Python的类,面向对象的东西和其它语言不太一样。比方实例的属性是能够动态分配的。本来没有的。能够自己加上,就算类中未定义,也能够用,挺方便的。可是建议能一次行定义完整最好,以下举个粒子:

>>> class Address(object):
...         def __init__(self,name,phone):
...               self.name = name
...               self.phone = phone
...
>>> jhon = Address('Jhon dov','123456')
>>> jhon.name
'Jhon dov'
>>> jhon.phone
'123456'
>>> jhon.wa = 'aaa'
>>> print jhon.wa
aaa

jhon.wa这个,就是实例属性的动态分配。原来类中未定义wa属性,可是我们能够通过jhon实例创建一个。

第二,可变不可变,传引用传值

究竟传值还是传引用。。

有时候会乱,那是由于理解不深刻啊。python中还是非常好区分的,举个粒子:

>>> list1 = [1,'a',['foo','bar'],('cc','opo')]
>>> list2 = list1
>>> list2[0]
1
>>> list2[2]
['foo', 'bar']
>>> list2[3]
('cc', 'opo')
>>> list2[3][0]
'cc'
>>> list2[0] = 2
>>> list2[2][0] = 'wang'
>>> list1
[2, 'a', ['wang', 'bar'], ('cc', 'opo')]
>>> list2
[2, 'a', ['wang', 'bar'], ('cc', 'opo')]
>>> list1[3][0] = 'dd'
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: 'tuple' object does not support item assignment

能够看出来。直接赋值的这样的传的是引用,就是说list1、list2指向的是内存中同样的地方,就像一个人取了俩名字,这点还是非常好理解的

再来个栗子:

>>> alist = list(list1)
>>> alist
[2, 'a', ['wang', 'bar'], ('cc', 'opo')]
>>> list1
[2, 'a', ['wang', 'bar'], ('cc', 'opo')]
>>> alist[0] = 3
>>> alist[1] = 'Z'
>>> alist[2][1] = "rab"
>>> alist[3][0] = "111"
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: 'tuple' object does not support item assignment
>>> alist[3] = ['1','2','3']
>>> alist
[3, 'Z', ['wang', 'rab'], ['1', '2', '3']]
>>> list1
[2, 'a', ['wang', 'rab'], ('cc', 'opo')]

这次不是直接赋值,可是一開始我们比較alist和list1,发现内容一样的。往下看,当对alist中的前两个元素更改的时候,最后与list1不一样了,list1的前两个元素没变。alist变了,这是由于前两个元素,一个是整数一个是字符串,都是不可变的。所以,alist中的前两个元素事实上是list1前两个元素的传值的效果。就是说两者仅仅是值同样,内存中有两份。可是内存中的位置不一样,所以更改alist中的前两个元素时。不影响list1中的;再看list1中的[‘wang‘,‘bar‘]。这本身就是个列表,我们知道,列表是可变的,所以在python中。这个列表传的是引用。内存中仅仅有一份,所以,改变alist中的这个列表,list1中的也会改变,最后演示了一下。列表中的元组,元组本身不可变,所以更改元组中内容会报错,且传递的是值,可是这个元组作为一个列表中的元素,我们能够总体替换掉。

可能说的比較乱,自己动手试试就知道了,这就是一个“浅拷贝”和“深拷贝”问题,浅拷贝顾名思义,拷贝的非常浅,能够理解为倒卖指针的家伙,同喝一杯饮料,就是传引用。再详细点的栗子就是,借别人一个东西。无论怎么借,东西就是一个,不会自己添加,假设有人把借的东西用坏了,那就真坏了;深拷贝,传值,每一个人一杯饮料。举个栗子就是,你看见别人一个杯子非常好看,你也想有一个。于是你也买了一个一样的杯子,两个杯子是一样的,可是所属人不一样,假设你不小心把杯子弄啐了,别人的杯子是不可能也跟着坏的。。。

第三,字符串抑制转义

新手一開始在读别人代码的时候,特别是读写文件那部分,总会遇到转义的问题,还有不明确转义是什么的也不在少数。照猫画虎的也有。真正理解事实上非常easy就是‘\’与其它字符拼在一起的时候。会变成其它的含义,下图给了几个样例

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcmVjc3lzbWw=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" >

另一个明显且常见的,file = open(‘C:\new\text.dat‘,‘w‘),我们觉得这是打开此文件夹下的dat文件。可是这样不行,由于\n是换行符,\t是制表符。那怎么解决?

一个通用的方法就是:字符串抑制转义,使用方法如:

file = open(r'C:\new\text.dat','w')

解释:假设r(大写或者小写)出如今字符串的第一个引號的前面,将会自己主动关闭转义机制

还能够这样解决:

file = open('C:\\new\\text.dat','w')

事实上这两种方式基本一样,如:

>>> path = r'C:\new\text.dat'
>>> path
'C:\\new\\text.dat'
>>> print path
C:\new\text.dat
>>> 

版权声明:本文博客原创文章,博客,未经同意,不得转载。

时间: 2024-10-22 02:10:18

Python缺乏调查的陷阱 动态实例属性、引用、逃生的相关文章

Python查缺补漏之动态实例属性

--看到哪里,想到哪里,记到哪里 很多时候,很多人学python的时候,会忽略的东西很多,大多数都盯着能"出货"就行,但是通常在读别人的代码的时候发现,看不懂...一方面是自己的代码技巧和经验不足:另一方面就是自己掌握的东西不全面,而这些往往是基础的东西,还不算高大上的东西.. 第一:动态实例属性 Python的类,面向对象的东西和其他语言不太一样,比如实例的属性是可以动态分配的,本来没有的,可以自己加上,就算类中没有定义,也可以用,挺方便的,但是建议能一次行定义完整最好,下面举个粒子

2015/9/20 Python基础(16):类和实例

面向对象编程编程的发展已经从简单控制流中按步的指令序列进入到更有组织的方式中,依靠代码块可以形成命名子程序和完成既定的功能.结构化的或过程性编程可以让我们把程序组织成逻辑快,以便重复或重用.创造程序的过程变得更具逻辑性:选出的行为要符合规范,才可以约束创建的数据.迪特尔父子认为结构化编程是“面向行为”的,因为事实上,即使没有任何行为的数据也必须“规定”逻辑性.然而,如果我们能对数据加上动作呢?如果我们所创建和编写的数据片段,是真实生活中实体的模型,内嵌数据体和动作呢?我们通过一系列已定义的接口(

python实例属性和类属性精讲

一:访问与改变 # -*-coding: UTF-8 -*- class ShuXing(object): class_shuxing = "class_shuxing" class_shuxing_list = [1, 2, 3] def __init__(self): self.instance_shuxing = "instance_shuxing" self.instance_shuxing_list = [5, 6, 7] print ShuXing.cl

python 之实例属性和类属性

由于Python是动态语言,根据类创建的实例可以任意绑定属性. 给实例绑定属性的方法是通过实例变量,或者通过self变量: class Student(object): def __init__(self, name): self.name = name s = Student('Bob') s.score = 90 但是,如果Student类本身需要绑定一个属性呢?可以直接在class中定义属性,这种属性是类属性,归Student类所有: class Student(object): name

【Python】[面性对象编程] 获取对象信息,实例属性和类属性

获取对象信息1.使用isinstance()判断class类型2.dir() 返回一个对象的所有属性和方法3.如果试图获取不存在的对象会抛出异常[AttributeError]4.正确利用对象内置函数的例子: def readImage(fp): if hasattr(fp,"read"): return readData(fp) return None 实例属性和类属性1.一句话,Python是动态语言,根据类创建的实例可以任意绑定属性.    注意:实例属性和雷属性的名字要保持不一

python 面向对象六 类属性和实例属性

一.实例属性 Python是动态语言,根据类创建的实例可以任意绑定属性. 1 >>> class Student(object): 2 ... def __init__(self, name): 3 ... self.name = name # 每个实例必须的属性 4 ... 5 >>> s = Student('Jack') 6 >>> s.score = 90 # 任意绑定属性 7 >>> s.name 8 'Jack' 9 &g

Python实用笔记 (22)面向对象编程——实例属性和类属性

由于Python是动态语言,根据类创建的实例可以任意绑定属性. 给实例绑定属性的方法是通过实例变量,或者通过self变量: class Student(object): def __init__(self, name): self.name = name s = Student('Bob') s.score = 90 但是,如果Student类本身需要绑定一个属性呢?可以直接在class中定义属性,这种属性是类属性,归Student类所有: class Student(object): name

Python 面向对象和实例属性

一.三大编程范式 编程范式即编程的方法论,标识一种编程风格. 我们学习完Python语法后,就可以写python代码了,然后每个人写代码的风格不同,这些不同的风格就代表了不同的流派. 如果把python的基本语法比作无数的基本功,那么不同的编程风格就好比不同的武林门派. 虽然大家风格不同,但是都可以完成你的编程需求,Python是一门面向对象编程语言,但是到目前为止,你从未接触面向对象编程,然而你已经可以解决很多问题了,在Python中并没有人强制你使用哪一种固定的风格. 根本就没有什么门派是天

python类对象动态添加属性和方法

class Person(): #创建一个类 def __init__(self,name): #定义初始化信息. self.name = name li = Person('李') #实例化Person('李'),给变量li li.age = 20 #再程序没有停止下,将实例属性age传入.动态语言的特点. Person.age = None #这里使用类名来创建一个属性age给类,默认值是None.Python支持的动态属性添加. def eat(self): #定义一个方法,不过这个方法再