码迷,mamicode.com
首页 > 其他好文 > 详细

内置的类方法

时间:2019-12-16 13:33:08      阅读:83      评论:0      收藏:0      [点我收藏+]

标签:tuple   ice   att   als   turn   一个   attr   and   属性   

# 内置的类方法 和 内置的函数之间有着千丝万缕的联系
# 双下方法
# obj.__str__  str(obj)
# obj.__repr__ repr(obj)
# class Teacher:
#     def __init__(self,name,salary):
#         self.name = name
#         self.salary = salary
#     def __str__(self):
#         return "Teacher‘s object :%s"%self.name
#     def __repr__(self):
#         return str(self.__dict__)
#     def func(self):
#         return ‘wahaha‘
# nezha = Teacher(‘哪吒‘,250)
# print(nezha)  # 打印一个对象的时候,就是调用a.__str__
# print(repr(nezha))
# print(‘>>> %r‘%nezha)
#a.__str__ --> object
# object  里有一个__str__,一旦被调用,就返回调用这个方法的对象的内存地址
# l = [1,2,3,4,5]   # 实例化 实例化了一个列表类的对象
# print(l)
# %s str()  直接打印 实际上都是走的__str__
# %r repr()  实际上都是走的__repr__
# repr 是str的备胎,但str不能做repr的备胎

# print(obj)/‘%s‘%obj/str(obj)的时候,实际上是内部调用了obj.__str__方法,如果str方法有,那么他返回的必定是一个字符串
# 如果没有__str__方法,会先找本类中的__repr__方法,再没有再找父类中的__str__。
# repr(),只会找__repr__,如果没有找父类的

# 内置的方法有很多
# 不一定全都在object中
# class Classes:
#     def __init__(self,name):
#         self.name = name
#         self.student = []
#     def __len__(self):
#         return len(self.student)
#     def __str__(self):
#         return ‘classes‘
# py_s9= Classes(‘python全栈9期‘)
# py_s9.student.append(‘二哥‘)
# py_s9.student.append(‘泰哥‘)
# print(len(py_s9))
# print(py_s9)

#__del__
# class A:
#     def __del__(self):   # 析构函数: 在删除一个对象之前进行一些收尾工作
#         self.f.close()
# a = A()
# a.f = open()   # 打开文件 第一 在操作系统中打开了一个文件 拿到了文件操作符存在了内存中
# del a          # a.f 拿到了文件操作符消失在了内存中
# del a   # del 既执行了这个方法,又删除了变量
# 引用计数


# __call__
class A:
    def __init__(self,name):
        self.name = name
    def __call__(self):
        ‘‘‘
        打印这个对象中的所有属性
        :return:
        ‘‘‘
        for k in self.__dict__:
            print(k,self.__dict__[k])
a = A(alex)()
dic = {k:v}
# 对象 : 存储属性 和调用方法
dic[k] = v
# class Foo:
#     def __init__(self,name,age,sex):
#         self.name = name
#         self.age = age
#         self.sex = sex
#
#     def __getitem__(self, item):
#         if hasattr(self,item):
#             return self.__dict__[item]
#
#     def __setitem__(self, key, value):
#         self.__dict__[key] = value
#
#     def __delitem__(self, key):
#         del self.__dict__[key]
#
# f = Foo(‘egon‘,38,‘男‘)
# print(f[‘name‘])
# f[‘hobby‘] = ‘男‘
# print(f.hobby,f[‘hobby‘])
# del f.hobby      # object 原生支持  __delattr__
# del f[‘hobby‘]   # 通过自己实现的
# print(f.__dict__)

# __init__ 初始化方法
# __new__  构造方法 : 创建一个对象
class A:
    def __init__(self):
        self.x = 1
        print(in init function)
    # def __new__(cls, *args, **kwargs):
    #     print(‘in new function‘)
    #     return object.__new__(A, *args, **kwargs)

# a1 = A()
# a2 = A()
# a3 = A()
# print(a1)
# print(a2)
# print(a3)
# print(a.x)

# 设计模式
# 23种
# 单例模式
# 一个类 始终 只有 一个 实例
# 当你第一次实例化这个类的时候 就创建一个实例化的对象
# 当你之后再来实例化的时候 就用之前创建的对象

# class A:
#     __instance = False
#     def __init__(self,name,age):
#         self.name = name
#         self.age = age
#     def __new__(cls, *args, **kwargs):
#         if cls.__instance:
#             return cls.__instance
#         cls.__instance = object.__new__(cls)
#         return cls.__instance
#
# egon = A(‘egg‘,38)
# egon.cloth = ‘小花袄‘
# nezha = A(‘nazha‘,25)
# print(nezha)
# print(egon)
# print(nezha.name)
# print(egon.name)
# print(nezha.cloth)


# class A:
#     def __init__(self,name):
#         self.name = name
#
#     def __eq__(self, other):
#         if self.__dict__ == other.__dict__:
#             return True
#         else:
#             return False
#
# ob1 = A(‘egon‘)
# ob2 = A(‘egg‘)
# print(ob1 == ob2)

# hash()   #__hash__
# class A:
#     def __init__(self,name,sex):
#         self.name = name
#         self.sex = sex
#     def __hash__(self):
#         return hash(self.name+self.sex)
#
# a = A(‘egon‘,‘男‘)
# b = A(‘egon‘,‘nv‘)
# print(hash(a))
# print(hash(b))
import json
from collections import namedtuple
Card = namedtuple(Card,[rank,suit])   # rank 牌面的大小 suit牌面的花色
# class FranchDeck:
#     ranks = [str(n) for n in range(2,11)] + list(‘JQKA‘)   # 2-A
#     suits = [‘红心‘,‘方板‘,‘梅花‘,‘黑桃‘]
#
#     def __init__(self):
#         self._cards = [Card(rank,suit) for rank in FranchDeck.ranks
#                                         for suit in FranchDeck.suits]
#
#     def __len__(self):
#         return len(self._cards)
#
#     def __getitem__(self, item):
#         return self._cards[item]
#
#     def __setitem__(self, key, value):
#         self._cards[key] = value
#
#     def __str__(self):
#         return json.dumps(self._cards,ensure_ascii=False)

# deck = FranchDeck()
# print(deck[10])
# from random import choice
# print(choice(deck))
# # print(choice(deck))
# from random import shuffle
# shuffle(deck)
# print(deck[10])
# print(deck)
# print(deck[:5])

# 内置函数 内置的模块 内置的基础类型 < --- >类的内置方法
# ==    __eq__
# len() __len__

# 100 名字 和 性别 年龄不同
# set
# class A:
#     def __init__(self,name,sex,age):
#         self.name = name
#         self.sex = sex
#         self.age = age
#
#     # def __eq__(self, other):
#     #     if self.name == other.name and self.sex == other.sex:
#     #         return True
#     #     return False
#
#     def __hash__(self):
#         return hash(self.name + self.sex)
# a = A(‘egg‘,‘男‘,38)
# b = A(‘egg‘,‘男‘,37)
# print(set((a,b)))   # unhashable

# set 依赖对象的 hash eq

内置的类方法

标签:tuple   ice   att   als   turn   一个   attr   and   属性   

原文地址:https://www.cnblogs.com/qwer-123/p/11311185.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!