微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

介绍Python中几个常用的类方法

内置方法 说明

 __init__(self,...) 初始化对象,在创建新对象时调用

 __del__(self) 释放对象,在对象被删除之前调用

 __new__(cls,*args,**kwd) 实例的生成操作

 __str__(self) 在使用print语句时被调用

 __getitem__(self,key) 获取序列的索引key对应的值,等价于seq[key]

 __len__(self) 在调用内联函数len()时被调用

 __cmp__(stc,dst) 比较两个对象src和dst

 __getattr__(s,name) 获取属性的值

 __setattr__(s,name,value) 设置属性的值

 __delattr__(s,name) 删除name属性

 __getattribute__() __getattribute__()功能__getattr__()类似

 __gt__(self,other) 判断self对象是否大于other对象

 __lt__(slef,other) 判断self对象是否小于other对象

 __ge__(slef,other) 判断self对象是否大于或者等于other对象

 __le__(slef,other) 判断self对象是否小于或者等于other对象

 __eq__(slef,other) 判断self对象是否等于other对象

 __call__(self,*args) 把实例对象作为函数调用

__init__():

__init__方法在类的一个对象被建立时,马上运行。这个方法可以用来对你的对象做一些你希望的初始化。注意,这个名称的开始和结尾都是双下划线。

代码例子:
 

#!/usr/bin/python
# Filename: class_init.py
class Person:
  def __init__(self,name):
    self.name = name
  def sayHi(self):
    print 'Hello,my name is',self.name
p = Person('Swaroop')
p.sayHi()

输出

Hello,my name is Swaroop

 

   说明:__init__方法定义为取一个参数name(以及普通的参数self)。在这__init__里,我们只是创建一个新的域,也称为name。注意它们是两个不同的变量,尽管它们有相同的名字。点号使我们能够区分它们。最重要的是,我们没有专门调用__init__方法,只是在创建一个类的新实例的时候,把参数包括在圆括号内跟在类名后面,从而传递给__init__方法。这是这种方法的重要之处。现在,我们能够在我们的方法中使用self.name域。这在sayHi方法中得到了验证。

__new__():

__new__()在__init__()之前被调用,用于生成实例对象.利用这个方法和类属性的特性可以实现设计模式中的单例模式.单例模式是指创建唯一对象吗,单例模式设计的类只能实例化一个对象.

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-
class Singleton(object):
  __instance = None            # 定义实例
 
  def __init__(self):
    pass
 
  def __new__(cls,**kwd):     # 在__init__之前调用
    if Singleton.__instance is None:  # 生成唯一实例
      Singleton.__instance = object.__new__(cls,**kwd)
    return Singleton.__instance

 

 __getattr__()、__setattr__()和__getattribute__():

当读取对象的某个属性时,python会自动调用__getattr__()方法.例如,fruit.color将转换为fruit.__getattr__(color).当使用赋值语句对属性进行设置时,python会自动调用__setattr__()方法.__getattribute__()的功能__getattr__()类似,用于获取属性的值.但是__getattribute__()能提供更好的控制,代码更健壮.注意,python中并不存在__setattribute__()方法.

代码例子:
 

#!/usr/bin/python
# -*- coding: UTF-8 -*-
class Fruit(object):
  def __init__(self,color = "red",price = 0):
    self.__color = color
    self.__price = price
     
  def __getattribute__(self,name):        # 获取属性方法
    return object.__getattribute__(self,name)
 
  def __setattr__(self,value):
    self.__dict__[name] = value
 
if __name__ == "__main__":
  fruit = Fruit("blue",10)
  print fruit.__dict__.get("_Fruit__color")    # 获取color属性
  fruit.__dict__["_Fruit__price"] = 5
  print fruit.__dict__.get("_Fruit__price")    # 获取price属性

 

__getitem__():

如果类把某个属性定义为序列,可以使用__getitem__()输出序列属性中的某个元素.假设水果店中销售多钟水果,可以通过__getitem__()方法获取水果店中的没种水果

代码例子:
 

#!/usr/bin/python
# -*- coding: UTF-8 -*-class FruitShop:
   def __getitem__(self,i):   # 获取水果店的水果
     return self.fruits[i]   
if __name__ == "__main__":
  shop = FruitShop()
  shop.fruits = ["apple","banana"]
  print shop[1]
  for item in shop:        # 输出水果店的水果
    print item,

 

输出为:

banana

apple banana

 

 __str__():

__str__()用于表示对象代表的含义,返回一个字符串.实现了__str__()方法后,可以直接使用print语句输出对象,也可以通过函数str()触发__str__()的执行.这样就把对象和字符串关联起来,便于某些程序的实现,可以用这个字符串来表示某个类

代码例子:
 

#!/usr/bin/python
# -*- coding: UTF-8 -*-
class Fruit:   
  '''Fruit类'''        #为Fruit类定义了文档字符串
  def __str__(self):     # 定义对象的字符串表示
    return self.__doc__
 
if __name__ == "__main__":
  fruit = Fruit()
  print str(fruit)      # 调用内置函数str()出发__str__()方法输出结果为:Fruit类
  print fruit         #直接输出对象fruit,返回__str__()方法的值,输出结果为:Fruit类

 

__call__():

在类中实现__call__()方法,可以在对象创建时直接返回__call__()的内容.使用该方法可以模拟静态方法

代码例子:
 

#!/usr/bin/python
# -*- coding: UTF-8 -*-
class Fruit:
  class Growth:    # 内部类
    def __call__(self):
      print "grow ..."
 
  grow = Growth()   # 调用Growth(),此时将类Growth作为函数返回,即为外部类Fruit定义方法grow(),grow()将执行__call__()内的代码
if __name__ == '__main__':
  fruit = Fruit()
  fruit.grow()     # 输出结果:grow ...
  Fruit.grow()     # 输出结果:grow ...

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用爬虫利器 Playwright,轻松爬取抖查查数据 我们先分析登录的接口,其中 url 有一些非业务参数:ts、he、sign、secret。 然后根据这些参数作为关键词,定位到相关的 js 代码。 最后,逐步进行代码的跟踪,发现大部分的代码被混淆加密了。 花费了大半天,来还原这些混淆加密的代码
轻松爬取灰豚数据的抖音商品数据 调用两次登录接口实现模拟登录 我们分析登录接口,发现调用了两次不同的接口;而且,需要先调用 https://login.huitun.com/weChat/userLogin,然后再调用 https://dyapi.huitun.com/userLogin 接口。 登
成功绕过阿里无痕验证码,一键爬取飞瓜数据 飞瓜数据的登录接口,接入了阿里云的无痕验证码;通过接口方式模拟登录,难度比较高。所以,我们使用自动化的方式来实现模拟登录,并且获取到 cookie 数据。 [阿里无痕验证码] https://help.aliyun.com/document_detail/1
一文教你从零开始入门蝉妈妈数据爬取,成功逆向破解数据加密算法 通过接口进行模拟登录 我们先通过正常登录的方式,分析对应的登录接口。通过 F12 打开谷歌浏览器的调试面板,可以看到登录需要传递的一些参数;其中看到密码是被加密了。 不过我们通过经验可以大概猜测一下,应该是通过 md5 算法加密了。 接下
抽丝剥茧成功破解红人点集的签名加密算法 抽丝剥茧破解登录签名算法,成功实现模拟登录 headers = {} phone_num = "xxxx" password = "xxxx" md5_hash = hashlib.md5() md5_hash.upda
轻松绕过 Graphql 接口爬取有米有数的商品数据 有米有数数据的 API 接口,使用的是一种 API 查询语言 graphql。所有的 API 只有一个入口,具体的操作隐藏在请求数据体里面传输。 模拟登录,获取 sessionId 调用登录接口,进行模拟登录。 cookies = {} head
我最近重新拾起了计算机视觉,借助Python的opencv还有face_recognition库写了个简单的图像识别demo,额外定制了一些内容,原本想打包成exe然后发给朋友,不过在这当中遇到了许多小问题,都解决了,记录一下踩过的坑。 1、Pyinstaller打包过程当中出现warning,跟d
说到Pooling,相信学习过CNN的朋友们都不会感到陌生。Pooling在中文当中的意思是“池化”,在神经网络当中非常常见,通常用的比较多的一种是Max Pooling,具体操作如下图: 结合图像理解,相信你也会大概明白其中的本意。不过Pooling并不是只可以选取2x2的窗口大小,即便是3x3,
记得大一学Python的时候,有一个题目是判断一个数是否是复数。当时觉得比较复杂不好写,就琢磨了一个偷懒的好办法,用异常处理的手段便可以大大程度帮助你简短代码(偷懒)。以下是判断整数和复数的两段小代码: 相信看到这里,你也有所顿悟,能拓展出更多有意思的方法~
文章目录 3 直方图Histogramplot1. 基本直方图的绘制 Basic histogram2. 数据分布与密度信息显示 Control rug and density on seaborn histogram3. 带箱形图的直方图 Histogram with a boxplot on t