首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Python中的File文件操作#学习猿地

关闭文件 close() ==> 关闭冰箱门 ### 文件操作相关函数 #### open() 打开文件 > 格式: open(文件的路径,打开的方式,[字符集]) #### Seek() 设置文件指针的位置...> ```python > fp.seek(0) # 把文件指针设置到文件的开头位置 > fp.seek(10)  # 设置文件指针的位置 > fp.seek(0,2) # 0,2是把文件指定设置在文件的末尾...> ``` #### write() 写入内容 > 格式:文件对象.write(字符串) #### writelines() 写入容器类型数据 > 格式:文件对象.write(容器类型数据) > >...utf-8') as fp:   res = fp.read()   print(res) ``` #### 文件的路径: ```python 文件路径 路径 url 统一资源定位符 #相对路径: 就像别人指路一样...针对文件的相对路径的表示,从当前目录开始计算    1.txt ==> 具体文件前没有任何表示时,默认为当前目录 和 ./1.txt 是一个位置    ./1.txt ==> ./ 代表当前目录中的 1

40510
您找到你想要的搜索结果了吗?
是的
没有找到

定制类和黑魔法

hasattr(object, name):用来检测object(适用于类、文件、模块或对象,一切皆对象)中有没有一个name字符串对应的方法或属性。...'male' setattr(object, key, value):对象object的属性key赋值value,既可以新增属性也可以修改已有属性的值。...使用__slots__一个不好的地方就是我们不能再实例添加新的属性了,因为实例中已经没有了用来保存属性的__dict__字典,只能使用在__slots__中定义的那些属性,即类中的__slots__中定义了哪些属性...,对象也只能使用那些属性对象不能自己去创建新属性(因为没有了__dict__),也不能修改类的属性,因为受类控制。     ...对象属性赋值时,调用了__setattr__(self, name, value)方法,这个方法中有一句self.

44710

Python中的File文件操作#学习猿地

关闭文件 close() ==> 关闭冰箱门 ### 文件操作相关函数 #### open() 打开文件 > 格式: open(文件的路径,打开的方式,[字符集]) #### Seek() 设置文件指针的位置...> ```python > fp.seek(0) # 把文件指针设置到文件的开头位置 > fp.seek(10) # 设置文件指针的位置 > fp.seek(0,2) # 0,2是把文件指定设置在文件的末尾...> ``` #### write() 写入内容 > 格式:文件对象.write(字符串) #### writelines() 写入容器类型数据 > 格式:文件对象.write(容器类型数据) > >...utf-8') as fp: res = fp.read() print(res) ``` #### 文件的路径: ```python 文件路径 路径 url 统一资源定位符 #相对路径: 就像别人指路一样...针对文件的相对路径的表示,从当前目录开始计算 1.txt ==> 具体文件前没有任何表示时,默认为当前目录 和 ./1.txt 是一个位置 ./1.txt ==> ./ 代表当前目录中的 1

38710

解决AttributeError: collections.defaultdict object has no attribute iteritems

而​​collections.defaultdict​​是Python字典的一个子类,继承了Python字典的所有方法和属性,因此也没有​​iteritems​​方法。...解决方案二:使用​​​dict()​​函数 另外一个解决方案是使用​​dict()​​函数来转换​​collections.defaultdict​​对象为普通的字典对象,然后再使用​​iteritems​​...通过使用​​.items()​​方法,我们可以正确遍历​​collections.defaultdict​​对象,避免了​​AttributeError​​错误。...作为​​dict​​的子类,​​collections.defaultdict​​继承了​​dict​​的所有方法和属性,可以像普通字典一样进行操作。...在遍历过程中,我们分别将键和值分别赋值​​key​​和​​value​​变量进行处理。

32310

Python中dir,hasattr,getattr,setattr,vars的使用

一、dir([object]) dir函数的目的是交互式使用,因此没有提供完整的属性列表,只列出一组“重要的”属性名。 dir函数能审查有或没有 __dict__ 属性对象。...如果没有指定的属性,getattr函数抛出AttributeError异常,或者返回 default 参数的值(如果设定了这个参数的话)。...对象没有home属性,setattr会创建home属性home属性赋值。 ?...五、vars([object]) 返回object 对象的 __dict__ 属性,如果实例所属的类定义了__slots__ 属性,实例没有__dict__属性,那么 vars 函数不能处理这个实例(相反...也就是我们在本地定义的类的属性,如果通过setattr对象添加属性,则vars中也会有添加的属性,返回的结果是属性名和属性值构成的字典。 ?

1.4K30

Python中反射和描述器总结

反射 在Python中,能够通过一个对象,找出type、class、attribute或者method的能力,成为反射。...函数与方法 内建函数: getattr(object,name[,degault])  通过name返回object的属性值,当属性不存在,将使用default返回,如果没有default,则抛出AttributeError...hasattr(object,name)  判断对象是否有这个名字的属性,name必须为字符串 反射相关的魔术方法 __getattr__() 一个类的属性会按照继承关系找,如果找不到,就会执行__getattr...__()方法,如果没有这个方法,就会抛出AttributeError异常表示找不到属性。...值将作为属性查找的结果 如果抛出AttributeError异常,则会直接调用__gutattr__方法,因为表述属性没有找到。

90520

核心编程笔记(13.P

__bases__# 子类的父类 (,) 因为P没有属性,C没有继承到什么,下面我们P添加一些属性: >>> class P:#父类 ...  ...,一般用于访问某属性前先作一下检查 getattr()和setattr()为取得和赋值对象属性 delattr()函数会从一个对象中删除属性 >>> class myClass(object): ....__init__() 13.12.6 vars() vars()与dir()相似,vars()返回一个字典,它包含了对象存储于其__dict__中的属性(键)及值,如果提供的对象没有这个属性,则会引发TypeError...__dict__或它的类(类的__dict__),或者祖先类(其__dict__)中找到时,才被调用 13.16.4  描述符 描述符是标识对象属性的一个代理,当需要属性时,可根据你遇到的情况,通过描述符或采用常规方式来访问它...元类一般用于创建类,在执行类定义时,解释器必须要知道这个类的正确的元类 解释器会先寻找类属性__metaclass__,如果属性存在,就将这个属性此类作为他的元类,如果此属性没有定义,他会想上查找父类中的

36730

Python获取对象属性的几种方式小结

(self,但没有写出来)绑定实例 t,透过 self.x 来设定值,即 t....__dict__ {'x': 'xiangzhangshu'} # 如果没有将x 赋值 self 的属性,而是直接 return,结果发生了变化 class Spring(object): ....# 仔细看看 dir() 的结果,还有__dict__属性吗?没有了,的确没有了。也就是说__slots__把__dict__挤出去了,它进入了类的属性。...a = A() a.x You use getattr # 对象属性赋值时候,调用了__setattr__(self, name, value)方法,这个方法中有一句 self....如果没有定义这个方法,就会引发 AttributeError,这在前面已经看到了。 以上这篇Python获取对象属性的几种方式小结就是小编分享大家的全部内容了,希望能给大家一个参考。

3.7K20

Python3内置函数表.md

test是t1实例化对象 #16.hasattr 注意对象属性是要传入字符串 print(hasattr(test,'x')) #‘x’是test对象属性 返回 True #17.getattr...获取对象属性值 print(getattr(test,'x')) #1024 print(getattr(test,'e','实例化对象没有 e 属性')) #有实例化对象没有 e 属性 #18....setattr 设置对象属性值 setattr(test,e,'Hello world') print(getattr(test,'e','实例化对象没有 e 属性')) #hello world...#19.delattr 删除对象属性 delattr(test,'e') #20.property() 利用属性设置属性(将方法再次进行封装调用,无论里面方法名怎么改,接口始终是不变得)!...__new__ 决定是否要使用该 __init__ 方法,因为 __new__ 可以调用其他类的构造方法或者直接返回别的实例对象来作为本类的实例,如果 __new__ 没有返回实例对象,则 __init

1.3K20

Python面向对象基础

,相当于动态的这个实例增加了一个属性,覆盖了类变量 属性查找顺序 __dict__: 实例变量的字典 __class__: 得到实例对应的类 先查找__dict__在查找__class__ 代码 In...类装饰器通常用于类增加属性,如果增加方法,则都是类级的方法。...访问控制 双下划线 所有双下划线开始,非双下划线结尾的成员,都是私有成员 严格的说, Python里没有真正私有成员 Python的私有成员是通过改名实现的:_类名 + 带双下划綫的属性 除非真的有必要...__dict__ # door对象含有的属性_Door__status Out[4]: {'_Door__status': 'closed', 'number': 1001} In [5]: door...__status = 'hahaha' # 对象创建了新的属性,并没有修改到__status In [6]: door.

1.1K30

Python中反射

__dir__()))  上例通过属性字典__dict__来访问对象属性,本质上就是利用反射的能力,但是上面的例子中,访问的方式不优雅,Python提供了内置的函数  内建函数意义getattr(object...,name[,default])通过name返回object的属性值,当属性不存在,将属性不存在,将使用default返回,如果没有default,则抛出AttributeError,name必须是字符串...,如果找不到,就会执行__getattr__()方法,如果没有这个方法,就会抛出AttributeError异常标识找不到属性 查找属性顺序为: instance__dict__---->instance.class.dict...__dict__) print(Point.z)  实例的所有的属性访问,第一个都会调用__getattribute__方法,它阻止了属性的查找,该方法应该返回值或者抛出一个AttributeError...异常  它的return值将作为属性查找的结果如果抛出AttributeError异常,则会直接调用__getattr__方法,因为属性没有找到 __getattribute__方法中为了避免在该方法中无线递归

85000

Python自学成才之路 魔术方法之属性访问控制

Python中提供了一些魔术方法来控制对象属性的访问,赋值,删除过程。...属性赋值魔术方法 __setattr__(self, key, value) 对象属性赋值或者添加新属性时会被调用。...属性删除魔术方法 __delattr__(self, item) 当删除一个对象属性时,该方法会被调用。...(item + "属性不存在") AttributeError: age属性不存在 案例中__setattr__方法控制添加属性属性赋值的过程,通过birth_date属性来计算出age属性的值。...__dict__的方式来访问或修改属性,这种方式看上去可行,但是存在一个问题,因为self.__dict__本身也是对象属性(只是这个属性比较特殊,它存放了对象的其它属性),所以每次访问self.

51220

Python内置(4)类相关的内置

name定义类的名称 bases定义基类,即超类 dict定义所有类属性和方法。...对象本身不受分配或删除的影响,只有箭头受其影响。但是现在没有箭头指向第一个物体,让它活着是没有意义的。因此,Python的“垃圾收集器(gc)”丢掉了它。现在我们只剩下一个object。...dir and vars: 一切都是字典 你有没有想过Python如何存储对象,它们的变量及方法?我们知道所有对象都有自己的属性和方法,但是Python究竟如何跟踪它们呢?...由于某种奇怪的原因,无法将任意变量赋object,但是可以赋自己创建的类的对象。 这是object的特性吗?...__dict__ AttributeError: 'SlottedClass' object has no attribute '__dict__' >>> s.

2.4K30

Python3内置函数表.md

test是t1实例化对象 #16.hasattr 注意对象属性是要传入字符串 print(hasattr(test,'x')) #‘x’是test对象属性 返回 True #17.getattr...获取对象属性值 print(getattr(test,'x')) #1024 print(getattr(test,'e','实例化对象没有 e 属性')) #有实例化对象没有 e 属性 #18....setattr 设置对象属性值 setattr(test,e,'Hello world') print(getattr(test,'e','实例化对象没有 e 属性')) #hello world...#19.delattr 删除对象属性 delattr(test,'e') #20.property() 利用属性设置属性(将方法再次进行封装调用,无论里面方法名怎么改,接口始终是不变得)!...__new__ 决定是否要使用该 __init__ 方法,因为 __new__ 可以调用其他类的构造方法或者直接返回别的实例对象来作为本类的实例,如果 __new__ 没有返回实例对象,则 __init

89330
领券