------Python面向对象初

下面写一个类的简单实用,以便方便理解类

  1. #python 3.5环境,解释器在linux需要改变
  2. #阅读手册查询readme文件
  3. #作者:S12-陈金彭
  4. class SchoolMember(object): #学院成员类
  5. member_nums = 0 # 类变量 | 类属性
  6. def __init__(self,name,age,sex): # 初始化默认方法
  7. self.name = name # 实例属性 | 成员属性 (self 调用自己的属性)
  8. self.age = age
  9. self.sex = sex
  10. self.enroll() # 自动调用注册方法
  11. def enroll(self):
  12. SchoolMember.member_nums += 1 #注册人数加1
  13. print('The [%s]school member [%s] is enrolled'%(self.member_nums,self.name))
  14. def tell(self):
  15. print('Hello,my name is [%s]'%self.name)
  16. class Teacher(SchoolMember): # Teacher继承SchoolMember的属性
  17. def __init__(self,name,age,sex,course,selary): # 重写自己的属性
  18. super(Teacher,self).__init__(name,age,sex) # 继承学院成员的属性
  19. # SchoolMember.__init__(self,name,age,sex) #老式经典继承方法
  20. self.course = course
  21. self.selary = selary
  22. def teaching(self):
  23. print('Teaching [%s] is teaching [%s],selary [%s]'%(self.name,self.course,self.selary))
  24. class Student(SchoolMember): # Student继承SchoolMember的属性
  25. def __init__(self,name,age,sex,course,tuition):
  26. super(Student,self).__init__(name,age,sex)
  27. self.course = course
  28. self.tuition = tuition
  29. def pay_tuition(self):
  30. print('student [%s] paying tuition [%s]'%(self.name,self.tuition))
  31.  
  32. # 实例化类 (把一个抽象的类变成一个具体的对象的过程叫做实例化)
  33. t1 = Teacher('chen','','men','PY','')
  34. t2 = Teacher('Alex','','men','PY','')
  35. S1 = Student('SanJiang','','women','Python','')
  36. S2 = Student('LuNan','','men','Python','')
  37.  
  38. t1.tell()
  39. t1.teaching()
  40. S1.tell()
  41. S1.pay_tuition()

老男孩python

面向对象的特性:

封装

封装最好理解了。封装是面向对象的特征之一,是对象和类概念的主要特性。

封装,也就是把客观事物封装成抽象的类,并且类可以把自己的数据和方法只让可信的类或者对象操作,对不可信的进行信息隐藏。

继承

面向对象编程 (OOP) 语言的一个主要功能就是“继承”。继承是指这样一种能力:它可以使用现有类的所有功能,并在无需重新编写原来的类的情况下对这些功能进行扩展。

通过继承创建的新类称为“子类”或“派生类”。

被继承的类称为“基类”、“父类”或“超类”。

继承的过程,就是从一般到特殊的过程。

要实现继承,可以通过“继承”(Inheritance)和“组合”(Composition)来实现。

在某些 OOP 语言中,一个子类可以继承多个基类。但是一般情况下,一个子类只能有一个基类,要实现多重继承,可以通过多级继承来实现。

继承概念的实现方式有三类:实现继承、接口继承和可视继承。

Ø         实现继承是指使用基类的属性和方法而无需额外编码的能力;
Ø         接口继承是指仅使用属性和方法的名称、但是子类必须提供实现的能力;
Ø         可视继承是指子窗体(类)使用基窗体(类)的外观和实现代码的能力。

在考虑使用继承时,有一点需要注意,那就是两个类之间的关系应该是“属于”关系。例如,Employee 是一个人,Manager 也是一个人,因此这两个类都可以继承 Person 类。但是 Leg 类却不能继承 Person 类,因为腿并不是一个人。

抽象类仅定义将由子类创建的一般属性和方法。

OO开发范式大致为:划分对象→抽象类→将类组织成为层次化结构(继承和合成) →用类与实例进行设计和实现几个阶段。

多态

 
多态性(polymorphisn)是允许你将父对象设置成为和一个或更多的他的子对象相等的技术,赋值之后,父对象就可以根据当前赋值给它的子对象的特性以不同的方式运作。简单的说,就是一句话:允许将子类类型的指针赋值给父类类型的指针。
那么,多态的作用是什么呢?我们知道,封装可以隐藏实现细节,使得代码模块化;继承可以扩展已存在的代码模块(类);它们的目的都是为了——代码重用。而多态则是为了实现另一个目的——接口重用!多态的作用,就是为了类在继承和派生的时候,保证使用“家谱”中任一类的实例的某一属性时的正确调用。
 
Pyhon不支持多态并且也用不到多态,多态的概念是应用于Java和C#这一类强类型语言中
 
通过Python模拟的多态
  1. class Animal:
  2.     def __init__(self, name):    # Constructor of the class
  3.         self.name = name
  4.     def talk(self):              # Abstract method, defined by convention only
  5.         raise NotImplementedError("Subclass must implement abstract method")
  6.  
  7. class Cat(Animal):
  8.     def talk(self):
  9.         return 'Meow!'
  10.  
  11. class Dog(Animal):
  12.     def talk(self):
  13.         return 'Woof! Woof!'
  14.  
  15. animals = [Cat('Missy'),
  16.            Dog('Lassie')]
  17.  
  18. for animal in animals:
  19.     print animal.name + ': ' + animal.talk()

多继承

Python的类如果继承了多个类,那么其寻找方法的方式有两种,分别是:深度优先广度优先

  • 当类是经典类时,多继承情况下,会按照深度优先方式查找
  • 当类是新式类时,多继承情况下,会按照广度优先方式查找

如果 当前类或者父类继承了object类,那么该类便是新式类,否则便是经典类

经典类多继承

  1. class D:
  2.  
  3. def bar(self):
  4. print 'D.bar'
  5.  
  6. class C(D):
  7.  
  8. def bar(self):
  9. print 'C.bar'
  10.  
  11. class B(D):
  12.  
  13. def bar(self):
  14. print 'B.bar'
  15.  
  16. class A(B, C):
  17.  
  18. def bar(self):
  19. print 'A.bar'
  20.  
  21. a = A()
  22. # 执行bar方法时
  23. # 首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去D类中找,如果D类中么有,则继续去C类中找,如果还是未找到,则报错
  24. # 所以,查找顺序:A --> B --> D --> C
  25. # 在上述查找bar方法的过程中,一旦找到,则寻找过程立即中断,便不会再继续找了
  26. a.bar()
  27.  
  28. 经典类多继承

经典类多继承

新式类多继承

  1. class D(object):
  2.  
  3. def bar(self):
  4. print 'D.bar'
  5.  
  6. class C(D):
  7.  
  8. def bar(self):
  9. print 'C.bar'
  10.  
  11. class B(D):
  12.  
  13. def bar(self):
  14. print 'B.bar'
  15.  
  16. class A(B, C):
  17.  
  18. def bar(self):
  19. print 'A.bar'
  20.  
  21. a = A()
  22. # 执行bar方法时
  23. # 首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去C类中找,如果C类中么有,则继续去D类中找,如果还是未找到,则报错
  24. # 所以,查找顺序:A --> B --> C --> D
  25. # 在上述查找bar方法的过程中,一旦找到,则寻找过程立即中断,便不会再继续找了
  26. a.bar()
  27.  
  28. 新式类多继承

新式类多继承

经典类:首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去D类中找,如果D类中么有,则继续去C类中找,如果还是未找到,则报错

新式类:首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去C类中找,如果C类中么有,则继续去D类中找,如果还是未找到,则报错

总结
  • 面向对象是一种编程方式,此编程方式的实现是基于对  和 对象 的使用
  • 类 是一个模板,模板中包装了多个“函数”供使用
  • 对象,根据模板创建的实例(即:对象),实例用于调用被包装在类中的函数
  • 面向对象三大特性:封装、继承和多态

----------------------------------------------类进阶---------------------------------------

类的成员

类的成员可以分为三大类:字段、方法和属性

注:所有成员中,只有普通字段的内容保存对象中,即:根据此类创建了多少对象,在内存中就有多少个普通字段。而其他的成员,则都是保存在类中,即:无论对象的多少,在内存中只创建一份。 

一、字段

字段包括:普通字段和静态字段,他们在定义和使用中有所区别,而最本质的区别是内存中保存的位置不同,

  • 普通字段属于对象
  • 静态字段属于
    1. class Province:
    2.  
    3. # 静态字段
    4. country '中国'
    5.  
    6. def __init__(self, name):
    7.  
    8. # 普通字段
    9. self.name = name
    10.  
    11. # 直接访问普通字段
    12. obj = Province('河北省')
    13. print obj.name
    14.  
    15. # 直接访问静态字段
    16. Province.country
    17.  
    18. 字段的定义和使用

    字段的定义和使用

由上述代码可以看出【普通字段需要通过对象来访问】【静态字段通过类访问】,在使用上可以看出普通字段和静态字段的归属是不同的。其在内容的存储方式如下:

  • 静态字段在内存中只保存一份
  • 普通字段在每个对象中都要保存一份

应用场景: 通过类创建对象时,如果每个对象都具有相同的字段,那么就使用静态字段

二、方法

方法包括:普通方法、静态方法和类方法,三种方法在内存中都归属于类,区别在于调用方式不同。

  • 普通方法:由对象调用;至少一个self参数;执行普通方法时,自动将调用该方法的对象赋值给self
  • 类方法:由调用; 至少一个cls参数;执行类方法时,自动将调用该方法的复制给cls
  • 静态方法:由调用;无默认参数;
  1. class Foo:
  2.  
  3. def __init__(self, name):
  4. self.name = name
  5.  
  6. def ord_func(self):
  7. """ 定义普通方法,至少有一个self参数 """
  8.  
  9. # print self.name
  10. print '普通方法'
  11.  
  12. @classmethod
  13. def class_func(cls):
  14. """ 定义类方法,至少有一个cls参数 """
  15.  
  16. print '类方法'
  17.  
  18. @staticmethod
  19. def static_func():
  20. """ 定义静态方法 ,无默认参数"""
  21.  
  22. print '静态方法'
  23.  
  24. # 调用普通方法
  25. f = Foo()
  26. f.ord_func()
  27.  
  28. # 调用类方法
  29. Foo.class_func()
  30.  
  31. # 调用静态方法
  32. Foo.static_func()
  33.  
  34. 方法的定义和使用

方法的定义和使用

相同点:对于所有的方法而言,均属于类(非对象)中,所以,在内存中也只保存一份。

不同点:方法调用者不同、调用方法时自动传入的参数不同。

三、属性  

如果你已经了解Python类中的方法,那么属性就非常简单了,因为Python中的属性其实是普通方法的变种。

对于属性,有以下三个知识点:

  • 属性的基本使用
  • 属性的两种定义方式

1、属性的基本使用

  1. # ############### 定义 ###############
  2. class Foo:
  3.  
  4. def func(self):
  5. pass
  6.  
  7. # 定义属性
  8. @property
  9. def prop(self):
  10. pass
  11. # ############### 调用 ###############
  12. foo_obj = Foo()
  13.  
  14. foo_obj.func()
  15. foo_obj.prop #调用属性
  16.  
  17. 属性的定义和使用

属性的基本使用

由属性的定义和调用要注意一下几点:

  • 定义时,在普通方法的基础上添加 @property 装饰器;
  • 定义时,属性仅有一个self参数
  • 调用时,无需括号
               方法:foo_obj.func()
               属性:foo_obj.prop

注意:属性存在意义是:访问属性时可以制造出和访问字段完全相同的假象,属性由方法变种而来,如果Python中没有属性,方法完全可以代替其功能。

实例:对于主机列表页面,每次请求不可能把数据库中的所有内容都显示到页面上,而是通过分页的功能局部显示,所以在向数据库中请求数据时就要显示的指定获取从第m条到第n条的所有数据(即:limit m,n),这个分页的功能包括:

  • 根据用户请求的当前页和总数据条数计算出 m 和 n
  • 根据m 和 n 去数据库中请求数据
  1. # ############### 定义 ###############
  2. class Pager:
  3.  
  4. def __init__(self, current_page):
  5. # 用户当前请求的页码(第一页、第二页...)
  6. self.current_page = current_page
  7. # 每页默认显示10条数据
  8. self.per_items = 10
  9.  
  10. @property
  11. def start(self):
  12. val = (self.current_page - 1) * self.per_items
  13. return val
  14.  
  15. @property
  16. def end(self):
  17. val = self.current_page * self.per_items
  18. return val
  19.  
  20. # ############### 调用 ###############
  21.  
  22. p = Pager(1)
  23. p.start 就是起始值,即:m
  24. p.end 就是结束值,即:n

从上述可见,Python的属性的功能是:属性内部进行一系列的逻辑计算,最终将计算结果返回。

2、属性的两种定义方式

属性的定义有两种方式:

  • 装饰器 即:在方法上应用装饰器
  • 静态字段 即:在类中定义值为property对象的静态字段

装饰器方式:在类的普通方法上应用@property装饰器

注:经典类中的属性只有一种访问方式,其对应被 @property 修饰的方法
      新式类中的属性有三种访问方式,并分别对应了三个被@property、@方法名.setter、@方法名.deleter修饰的方法,我们可以根据他们几个属性的访问特点,分别将三个方法定义为对同一个属性:获取、修改、删除

经典类

  1. # ############### 定义 ###############
  2. class Goods:
  3.  
  4. @property
  5. def price(self):
  6. return "wupeiqi"
  7. # ############### 调用 ###############
  8. obj = Goods()
  9. result = obj.price # 自动执行 @property 修饰的 price 方法,并获取方法的返回值

经典类 - property

新式类

  1. class Goods(object):
  2.  
  3. def __init__(self):
  4. # 原价
  5. self.original_price = 100
  6. # 折扣
  7. self.discount = 0.8
  8.  
  9. @property
  10. def price(self):
  11. # 实际价格 = 原价 * 折扣
  12. new_price = self.original_price * self.discount
  13. return new_price
  14.  
  15. @price.setter
  16. def price(self, value):
  17. self.original_price = value
  18.  
  19. @price.deleter
  20. def price(self):
  21. del self.original_price
  22.  
  23. obj = Goods()
  24. print(obj.price) # 获取商品价格
  25. obj.price = 200 # 修改商品原价
  26. print(obj.price)
  27. del obj.price # 删除商品原价 ,在打印就报错

新式类 - property 增删

静态字段方式,创建值为property对象的静态字段

当使用静态字段的方式创建属性时,经典类和新式类无区别

  1. class Foo:
  2.  
  3. def get_bar(self):
  4. return 'wupeiqi'
  5.  
  6. BAR = property(get_bar)
  7.  
  8. obj = Foo()
  9. reuslt = obj.BAR # 自动调用get_bar方法,并获取方法的返回值
  10. print reuslt

property的构造方法中有个四个参数

  • 第一个参数是方法名,调用 对象.属性 时自动触发执行方法
  • 第二个参数是方法名,调用 对象.属性 = XXX 时自动触发执行方法
  • 第三个参数是方法名,调用 del 对象.属性 时自动触发执行方法
  • 第四个参数是字符串,调用 对象.属性.__doc__ ,此参数是该属性的描述信息
  1. class Foo:
  2. A='wupeiqi'
  3.  
  4. def get_bar(self):
  5. return self.A
  6.  
  7. # *必须两个参数
  8. def set_bar(self, value):
  9. self.A = value
  10.  
  11. def del_bar(self):
  12. return 'wupeiqi'
  13.  
  14. BAR=property(get_bar, set_bar, del_bar)
  15.  
  16. obj = Foo()
  17.  
  18. print(obj.BAR) # 自动调用第一个参数中定义的方法:get_bar
  19. obj.BAR = "alex" # 自动调用第二个参数中定义的方法:set_bar方法,并将“alex”当作参数传入
  20. print(obj.BAR)
  21. # del Foo.BAR # 自动调用第三个参数中定义的方法:del_bar方法
  22. A=obj.BAR.__doc__ # 自动获取第四个参数中设置的值:description...
  23. print(A)

注意:Python WEB框架 Django 的视图中 request.POST 就是使用的静态字段的方式创建的属性

  1. class WSGIRequest(http.HttpRequest):
  2. def __init__(self, environ):
  3. script_name = get_script_name(environ)
  4. path_info = get_path_info(environ)
  5. if not path_info:
  6. # Sometimes PATH_INFO exists, but is empty (e.g. accessing
  7. # the SCRIPT_NAME URL without a trailing slash). We really need to
  8. # operate as if they'd requested '/'. Not amazingly nice to force
  9. # the path like this, but should be harmless.
  10. path_info = '/'
  11. self.environ = environ
  12. self.path_info = path_info
  13. self.path = '%s/%s' % (script_name.rstrip('/'), path_info.lstrip('/'))
  14. self.META = environ
  15. self.META['PATH_INFO'] = path_info
  16. self.META['SCRIPT_NAME'] = script_name
  17. self.method = environ['REQUEST_METHOD'].upper()
  18. _, content_params = cgi.parse_header(environ.get('CONTENT_TYPE', ''))
  19. if 'charset' in content_params:
  20. try:
  21. codecs.lookup(content_params['charset'])
  22. except LookupError:
  23. pass
  24. else:
  25. self.encoding = content_params['charset']
  26. self._post_parse_error = False
  27. try:
  28. content_length = int(environ.get('CONTENT_LENGTH'))
  29. except (ValueError, TypeError):
  30. content_length = 0
  31. self._stream = LimitedStream(self.environ['wsgi.input'], content_length)
  32. self._read_started = False
  33. self.resolver_match = None
  34.  
  35. def _get_scheme(self):
  36. return self.environ.get('wsgi.url_scheme')
  37.  
  38. def _get_request(self):
  39. warnings.warn('`request.REQUEST` is deprecated, use `request.GET` or '
  40. '`request.POST` instead.', RemovedInDjango19Warning, 2)
  41. if not hasattr(self, '_request'):
  42. self._request = datastructures.MergeDict(self.POST, self.GET)
  43. return self._request
  44.  
  45. @cached_property
  46. def GET(self):
  47. # The WSGI spec says 'QUERY_STRING' may be absent.
  48. raw_query_string = get_bytes_from_wsgi(self.environ, 'QUERY_STRING', '')
  49. return http.QueryDict(raw_query_string, encoding=self._encoding)
  50.  
  51. # ############### 看这里看这里 ###############
  52. def _get_post(self):
  53. if not hasattr(self, '_post'):
  54. self._load_post_and_files()
  55. return self._post
  56.  
  57. # ############### 看这里看这里 ###############
  58. def _set_post(self, post):
  59. self._post = post
  60.  
  61. @cached_property
  62. def COOKIES(self):
  63. raw_cookie = get_str_from_wsgi(self.environ, 'HTTP_COOKIE', '')
  64. return http.parse_cookie(raw_cookie)
  65.  
  66. def _get_files(self):
  67. if not hasattr(self, '_files'):
  68. self._load_post_and_files()
  69. return self._files
  70.  
  71. # ############### 看这里看这里 ###############
  72. POST = property(_get_post, _set_post)
  73.  
  74. FILES = property(_get_files)
  75. REQUEST = property(_get_request)
  76.  
  77. Django源码

Django源码

所以,定义属性共有两种方式,分别是【装饰器】和【静态字段】,而【装饰器】方式针对经典类和新式类又有所不同

类成员的修饰符

  • 公有成员,在任何地方都能访问
  • 私有成员,只有在类的内部才能方法

私有成员和公有成员的定义不同:私有成员命名时,前两个字符是下划线。(特殊成员除外,例如:__init__、__call__、__dict__等)

  1. class C:
  2.  
  3. def __init__(self):
  4. self.name = '公有字段'
  5. self.__foo = "私有字段"

私有成员和公有成员的访问限制不同

静态字段

  • 公有静态字段:类可以访问;类内部可以访问;派生类中可以访问
  • 私有静态字段:仅类内部可以访问;
  1. class C:
  2.  
  3. name = "公有静态字段"
  4.  
  5. def func(self):
  6. print (C.name)
  7.  
  8. class D(C):
  9.  
  10. def show(self):
  11. print (C.name)
  12.  
  13. C.name # 类访问
  14.  
  15. obj = C()
  16. obj.func() # 类内部可以访问
  17.  
  18. obj_son = D()
  19. obj_son.show() # 派生类中可以访问

公有静态字段

  1. class C:
  2.  
  3. __name = "公有静态字段"
  4.  
  5. def func(self):
  6. print (C.__name)
  7.  
  8. class D(C):
  9.  
  10. def show(self):
  11. print (C.__name)
  12.  
  13. # C.__name # 类访问 ==> 错误
  14.  
  15. obj = C()
  16. obj.func() # 类内部可以访问 ==> 正确
  17.  
  18. obj_son = D()
  19. obj_son.show() # 派生类中可以访问 ==> 错误

私有静态字段

普通字段

  • 公有普通字段:对象可以访问;类内部可以访问;派生类中可以访问
  • 私有普通字段:仅类内部可以访问;

ps:如果想要强制访问私有字段,可以通过 【对象._类名__私有字段明 】访问(如:obj._C__foo),不建议强制访问私有成员。

  1. class C(object):
  2.  
  3. def __init__(self):
  4. self.foo = "公有字段"
  5.  
  6. def func(self):
  7. print(self.foo)# 类内部访问
  8. class D(C):
  9. def show(self):
  10. print(self.foo) #派生类中访问
  11.  
  12. obj = C()
  13. print(obj.foo)
  14.  
  15. obj.foo # 通过对象访问
  16. obj.func() # 类内部访问
  17.  
  18. obj_son = D();
  19. obj_son.show() # 派生类中访问

公有字段

  1. class C(object):
  2.  
  3. def __init__(self):
  4. self.__foo = "私有字段"
  5.  
  6. def func(self):
  7. print(self.__foo)# 类内部访问
  8.  
  9. class D(C):
  10.  
  11. def show(self):
  12. print (self.__foo) #派生类中访问
  13.  
  14. obj = C()
  15. obj.__foo # 通过对象访问 ==> 错误
  16. obj.func() # 类内部访问 ==> 正确
  17. obj_son = D();
  18. obj_son.show() # 派生类中访问 ==> 错误

私有字段

ps:非要访问私有属性的话,可以通过 对象._类__属性名 例如:  print(obj_son._C__foo)

 

类的特殊成员

上文介绍了Python的类成员以及成员修饰符,从而了解到类中有字段、方法和属性三大类成员,并且成员名前如果有两个下划线,则表示该成员是私有成员,私有成员只能由类内部调用。无论人或事物往往都有不按套路出牌的情况,Python的类成员也是如此,存在着一些具有特殊含义的成员,详情如下:

1. __doc__

  表示类的描述信息

  1. class Foo:
  2. """ 描述类信息,这是用于看片的神奇 """
  3.  
  4. def func(self):
  5. pass
  6.  
  7. print Foo.__doc__
  8. #输出:类的描述信息

2. __module__ 和  __class__ 

  __module__ 表示当前操作的对象在那个模块

  __class__     表示当前操作的对象的类是什么

  1. #!/usr/bin/env python
  2. # -*- coding:utf- -*-
  3.  
  4. class C:
  5.  
  6. def __init__(self):
  7. self.name = 'wupeiqi'
  1. from learning import C
  2.  
  3. obj = C()
  4. print (obj.__module__) #输出模块
  5. print (obj.__class__ ) #输出类

3. __init__

  构造方法,通过类创建对象时,自动触发执行。

  1. class Foo:
  2.  
  3. def __init__(self, name):
  4. self.name = name
  5. self.age =
  6.  
  7. obj = Foo('wupeiqi') # 自动执行类中的 __init__ 方法

4. __del__

  析构方法,当对象在内存中被释放时,自动触发执行。

注:此方法一般无须定义,因为Python是一门高级语言,程序员在使用时无需关心内存的分配和释放,因为此工作都是交给Python解释器来执行,所以,析构函数的调用是由解释器在进行垃圾回收时自动触发执行的。

  1. class Foo:
  2.  
  3. def __del__(self):
  4. pass

5. __call__

  对象后面加括号,触发执行。

注:构造方法的执行是由创建对象触发的,即:对象 = 类名() ;而对于 __call__ 方法的执行是由对象后加括号触发的,即:对象() 或者 类()()

  1. class Foo:
  2.  
  3. def __init__(self):
  4. pass
  5.  
  6. def __call__(self, *args, **kwargs):
  7.  
  8. print ('__call__')
  9.  
  10. obj = Foo() # 执行 __init__
  11. obj() # 执行 __call__

6. __dict__

  类或对象中的所有成员

上文中我们知道:类的普通字段属于对象;类中的静态字段和方法等属于类,即:

  1. class Province:
  2.  
  3. country = 'China'
  4.  
  5. def __init__(self, name, count):
  6. self.name = name
  7. self.count = count
  8.  
  9. def func(self, *args, **kwargs):
  10. print ('func')
  11.  
  12. # 获取类的成员,即:静态字段、方法、
  13. print (Province.__dict__)
  14. # 输出:{'country': 'China', '__module__': '__main__', 'func': <function func at 0x10be30f50>, '__init__': <function __init__ at 0x10be30ed8>, '__doc__': None}
  15.  
  16. obj1 = Province('HeBei',)
  17. print (obj1.__dict__)
  18. # 获取 对象obj1 的成员
  19. # 输出:{'count': , 'name': 'HeBei'}
  20.  
  21. obj2 = Province('HeNan', )
  22. print (obj2.__dict__)
  23. # 获取 对象obj1 的成员
  24. # 输出:{'count': , 'name': 'HeNan'}

7. __str__

  如果一个类中定义了__str__方法,那么在打印 对象 时,默认输出该方法的返回值。

  1. class Foo:
  2.  
  3. def __str__(self):
  4. return 'wupeiqi'
  5.  
  6. obj = Foo()
  7. print (obj)
  8. # 输出:wupeiqi

8、__getitem__、__setitem__、__delitem__

用于索引操作,如字典。以上分别表示获取、设置、删除数据

  1. class Foo(object):
  2.  
  3. def __getitem__(self, key):
  4. print ('__getitem__',key)
  5.  
  6. def __setitem__(self, key, value):
  7. print ('__setitem__',key,value)
  8.  
  9. def __delitem__(self, key):
  10. print ('__delitem__',key)
  11.  
  12. obj = Foo()
  13.  
  14. result = obj['k1'] # 自动触发执行 __getitem__
  15. obj['k2'] = 'wupeiqi' # 自动触发执行 __setitem__
  16. del obj['k1'] # 自动触发执行 __delitem__

9、__getslice__、__setslice__、__delslice__

该三个方法用于分片操作,如:列表

参考金角银角博客:

金角:http://www.cnblogs.com/alex3714/articles/5188179.html

银角:http://www.cnblogs.com/wupeiqi/p/4493506.html

python 面向对象学习的更多相关文章

  1. Python面向对象学习 1 (什么是面向对象,面向对象的应用场景,待更新)

    程序设计的三种基本结构: 面向对象,面向过程,函数式编程   1,什么是面向对象编程    面向对象编程是一种编程方式,此编程方式的落地需要使用 “类” 和 “对象” 来实现,所以,面向对象编程其实就 ...

  2. python面向对象学习(二)基本语法

    目录 1. dir内置函数 2. 定义简单的类(只包含方法) 2.1 定义只包含方法的类 2.2 创建对象 2.3 编写第一个面向对象程序 3. 方法中的self参数 3.1 案例改造 -- 给对象添 ...

  3. python面向对象学习(一)基本概念

    目录 1. 面向对象基本概念 1.1 过程和函数 1.2 面相过程 和 面相对象 基本概念 2. 类和对象的概念 1.1 类 1.3 对象 3. 类和对象的关系 4. 类的设计 大驼峰命名法 4.1 ...

  4. Python面向对象学习2(面向对象的语法和特性,待更新)

    上一个内容我们介绍了面向对象和面向对象场景现在我们来学习下语法和特性 1,面向对象基本语法: # -*- coding:utf-8 -*- # Author: Colin Yao class Dog( ...

  5. python面向对象学习笔记(一)

    粘贴一些自学过程中的笔记大纲,源文本在pycharm里面写的,有点乱整理一下,部分内容有待补充,书写不一定100%正确,全当数据备份了. 1.面向对象的特性 #你写代码时什么使用面向对象 #处理比较复 ...

  6. Python面向对象学习

    以下面例子作为面向对象基础介绍,类比java里的面向对象既可以,大同小异 class Employee(): raiseAmount=1.04 employeeNum= def __init__(se ...

  7. python面向对象学习(七)单例

    目录 1. 单例设计模式 单例设计模式的应用场景 2. __new__ 方法 3. Python 中的单例 只执行一次初始化工作 1. 单例设计模式 设计模式 设计模式 是 前人工作的总结和提炼,通常 ...

  8. python面向对象学习(六)类属性、类方法、静态方法

    目录 1. 类的结构 1.1 术语 -- 实例 1.2 类是一个特殊的对象 2. 类属性和实例属性 2.1 概念和使用 2.2 属性的获取机制 3. 类方法和静态方法 3.1 类方法 3.2 静态方法 ...

  9. python面向对象学习(四)继承

    目录 1. 单继承 1.1 继承的概念.语法和特点 1.2 方法的重写 1.3 父类的 私有属性 和 私有方法 2. 多继承 2.1 多继承的使用注意事项 2.2 新式类与旧式(经典)类 1. 单继承 ...

随机推荐

  1. 饮水思源——python中常用基础类源码解析

    1.bool类 2.int类 3.long类 4.float类 5.str类 6.list类 7.tuple类 8.dict类 9.collections类 Counter类:为hashable对象计 ...

  2. linux下多路复用模型之Select模型

    Linux关于并发网络分为Apache模型(Process per Connection (进程连接) ) 和TPC , 还有select模型,以及poll模型(一般是Epoll模型) Select模 ...

  3. 51nod1693 水群

    题目链接:51nod1693 水群 题解参考大神的博客:http://www.cnblogs.com/fighting-to-the-end/p/5874763.html 这题时限0.4秒,真的够狠的 ...

  4. python练习题代码

    1.打印出相应规则的字母 zm='ABCDEFGHIJKLMNOPQRSTUVWXYZ' >>> for i in range(0,len(zm)): if i==0:  print ...

  5. guava学习--FluentIterable

    public class FluentIterableTest { public static void main(String[] args) { Man man1 = new Man(" ...

  6. Servlet里面url-pattern的通配符*的使用规则

    简单来说: 以”/’开头和以”/*”结尾的是用来做路径映射的. 以前缀”*.”开头的是用来做扩展映射的. “/” 是用来定义default servlet映射的. 剩下的都是用来定义详细映射的.比如: ...

  7. Apache+Tomcat构建Tomcat负载均衡集群

    一.环境介绍 二.安装后端服务器 三.安装前端Apache服务 四.配置Apache使用mod_jk模块实现代理及负载均衡 五.配置Apache基于mod_proxy模块实现代理及负载均衡 六.论坛安 ...

  8. Python开发入门与实战3-Django动态页面

    3.Django动态页面 上一章节我们实现的helloworld视图是用来演示Django网页是创建的,它不是一个动态网页,每次运行/helloworld/,我们都将看到相同的内容,它类似一个静态HT ...

  9. Oracle GoldenGate for Big Data 12.2.0.1的新特性

    ogg for bigdata 12.2已经发布,新增有如下特性:支持java replicat进程OGG12.2中开发了基于java的replicat模式,以前的版本是基于extract进程中使用u ...

  10. MVC 微信支付

    微信支付方式有好几种,俺研究了跟自己需要的两种,即:JS API网页支付和Native原生支付,这两个名词实在是有目的难懂.JS API网页支付:我的理解是在微信浏览器里面可以调用微信支付控件的支付方 ...