A、成员:
1.字段:静态字段(每个对象都有同一字段),普通字典(每个对象都有不同的数据)
2.方法:静态方法(无需使用对象的内容),类方法,普通方法(使用对象中的数据)
3.特性:普通特性(将方法伪造成字段)
   通过类去访问的有:静态字段,静态方法,类方法
   通过对象去访问的有:普通字段,类的方法
   自己的成员自己去访问
   静态方法:没有self,前添加@staticmethod,即为静态方法(通过类去访问)
   类方法:比静态方法多一个参数,该参数是为了显示哪个类,前添加@classmethod
   特性:将方法未造成字段来执行,前添加@property 快速判断,类执行,对象执行
self 对象调用
无self 类调用
test01
class Provice:

    #静态字段,类中
country="China" def __init__(self,name): #普通字段,对象中
self.name=name #普通方法,类中
def show(self):
print("show") #静态方法
@staticmethod
def add():
print("加法") #类方法,多一个参数
@classmethod
def dev(cls):
print("减法",cls) #特性,将方法未造成字段来执行
@property
def csv(self):
print("csv") #设置csv中的值,3个csv处名字必须相同
@csv.setter
def csv(self,value):
print(value)
pro=Provice("山东")
print(Provice.country)
print(pro.name)
Provice.add()
print(Provice.dev())
print(pro.csv)
pro.csv="123456"
-------------------------------------------------

  China
  山东
  加法
  减法 <class '__main__.Provice'>
  csv
  123456

B、利用反射导入模块、查找类、创建对象、查找对象中的字
imp=__import__("test01",fromlist=True)
print(imp) class_name=getattr(imp,"Foo")
print(class_name) r=class_name('zhangyu')
print(r)
print(getattr(r,'name'))
----------------------------------------

  <module 'test01' from 'F:\\myworkspacedirectory\\Function\\member\\test01.py'>
  <class 'test01.Provice'>
  <test01.Provice object at 0x00000247FEFC79E8>
  zhangyu

C、成员修饰符
成员:
字段:静态字段(每个对象都有同一字段),普通字典(每个对象都有不同的数据)
方法:静态方法(无需使用对象的内容),类方法,普通方法(使用对象中的数据)
特性:普通特性(将方法伪造成字段)
两种:共有的,私有的(两个下划线开头,只有自己能使用,派生类也不能访问)
class Provice:

    #静态字段,类中
country="China" #私有字段,供内部使用
__country = "Eglish" def __init__(self,name,name1): #普通字段,对象中
self.name=name
#私有的有普通字段
self.__name1=name1 def __add(self):
print("__add") @staticmethod
def __dev():
print("__dev") # 普通方法,类中
def show(self):
print("show")
print(Provice.__country)
self.__name1="666"
self.__add()
self.__dev() @staticmethod
def mm():
Provice.__dev
Provice.__name1 = "6661" obj=Provice("zhangyu","nnn")
print(Provice.country) #错误情况
#print(Provice.__country)
obj.show()
Provice.mm()
---------------------------------------------

  China
  show
  Eglish
  __add
  __dev

D、类的特殊成员1
__init__
__del__
__call__===>Django
xxx.__dict__:可查看类中的成员
class Foo:
'''
我是类的注释
'''
country="zhongguo" def __init__(self):
self.name="666" def __call__(self, *args, **kwargs):
print("call")
return 1 def __getitem__(self, item):
print(item,type(item),"__getitem__") def __setitem__(self, key, value):
print(key,value,"__setitem__") def __delitem__(self, key):
print(key,"__delitem__") def add(self):
print("1") # r=Foo()()
# print(r) r=Foo() #------------->执行init
r() #------------------>执行__call__
r['k1'] #------------------>执行__getitem__
r['k2']='666' #------------------>执行__setitem__
del r['xxx'] #------------------>执行__执行__delitem__
r[1:5:2] #2.7执行getslice 3.0执行getitem
r[1:3:3]=[11,22,33,44,55,66] #2.7执行setslice 3.0执行setitem
del r[1:3:3] #2.7执行detslice 3.0执行detitem print(r.__dict__)
print(Foo.__dict__)
----------------------------------------------

  call
  k1 <class 'str'> __getitem__
  k2 666 __setitem__
  xxx __delitem__
  slice(1, 5, 2) <class 'slice'> __getitem__
  slice(1, 3, 3) [11, 22, 33, 44, 55, 66] __setitem__
  slice(1, 3, 3) __delitem__
  {'name': '666'}

{'__module__': '__main__', '__doc__': '\n 我是类的注释\n ', 'country': 'zhongguo', '__init__': <function Foo.__init__ at 0x000001C307CB8950>, '__call__': <function Foo.__call__ at 0x000001C307CB89D8>, '__getitem__': <function Foo.__getitem__ at 0x000001C307CB8A60>, '__setitem__': <function Foo.__setitem__ at 0x000001C307CB8AE8>, '__delitem__': <function Foo.__delitem__ at 0x000001C307CB8B70>, 'add': <function Foo.add at 0x000001C307CB8BF8>, '__dict__': <attribute '__dict__' of 'Foo' objects>, '__weakref__': <attribute '__weakref__' of 'Foo' objects>}

E、iter:类的特殊成员2
class Foo:

    def __iter__(self):
yield 1
yield 2
yield 3
yield 4 obj=Foo()
#如果执行for对象时,自动会执行对象的iter方法,生成器
for i in obj:
print(i)
----------------------------------------------------
1
2
3
4


四十一、python面向对象二的更多相关文章

  1. python面向对象(二)——类成员

    Python面向对象    类成员 1.字段         普通字段    属于对象         静态字段    属于类   2.方法 普通方法   触发者是对象    括号里至少一个参数 se ...

  2. 第三十四篇 Python面向对象之 反射(自省)

    什么是反射? 反射的概念是由Smith在1982年提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省).这一概念的提出很快引发了计算机科学领域关于应用反射性的研究.它首先被程序语 ...

  3. python 面向对象二 类和实例

    一.类和实例 面向对象最重要的概念就是类(Class)和实例(Instance),必须牢记类是抽象的模板,比如Student类,而实例是根据类创建出来的一个个具体的“对象”,每个对象都拥有相同的方法, ...

  4. python面向对象二

    1.1类的静态属性,类方法,类的静态方法 1.1.1静态属性(@property) 在类中: python内置的@property装饰器就是负责把一个方法(函数)变成属性来调用. class Stud ...

  5. Java从零开始学四十一(反射简述二)

    一.实例化Class类对象 实例化Class类对象的方法有三种: 第一种:通过forName()方法 第二种:类.class 第三种:对象.getClass() 二.Class类的常用方法 No. 方 ...

  6. Python 面向对象(二) 特殊方法

    一些Python特殊方法的汇总 __bases__    类的基类,返回元祖__base__  类的基类,也叫父类__call__ '类名()',类名加括号调用时执行的语句__class__ 对象或类 ...

  7. 四十一 Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)基本的索引和文档CRUD操作、增、删、改、查

    elasticsearch(搜索引擎)基本的索引和文档CRUD操作 也就是基本的索引和文档.增.删.改.查.操作 注意:以下操作都是在kibana里操作的 elasticsearch(搜索引擎)都是基 ...

  8. python面向对象(二)

    属性查找 类有两种属性:数据属性和函数属性 1. 类的数据属性是所有对象共享的 2. 类的函数属性是绑定给对象用的 class BeijingStudent:   school='Beijing'  ...

  9. python 面向对象(二)--访问限制

    在Class内部,可以有属性和方法,而外部代码可以通过直接调用实例变量的方法来操作数据,这样,就隐藏了内部的复杂逻辑. 但是,从前面Student类的定义来看,外部代码还是可以自由地修改一个实例的na ...

随机推荐

  1. centos7 设置内核启动顺序

    1.查看设备上安装了几个内核 cat /boot/grub2/grub.cfg |grep menuentry 2.查看当前内核 grub2-editenv list saved_entry=Cent ...

  2. Ajax跳入error的原因

    1. dataType错误 我遇到的就是这个dataType错误,即后台返回的dataType类型与前台写的不一致,一般前台写json没问题,大部分是后台返回的类型对不上 2. async请求同步异步 ...

  3. 在Linux中让echo命令显示带颜色的字

    echo显示带颜色,需要使用参数-e 格式如下: echo -e "\033[字背景颜色;文字颜色m字符串\033[0m" 例如: echo -e "\033[41;37 ...

  4. [工具] BurpSuite--Intruder功能

    BurpSuite--Intruder功能 0x00 配置说明 intruder是进行爆破的,基本流程是标注请求的爆破参数,然后配置字段,选择爆破方式进行爆破,下面来记录下工具的使用 选中intrud ...

  5. 五种I/O模型

    文档地址:https://www.cse.huji.ac.il/course/2004/com1/Exercises/Ex4/I.O.models.pdf 五种I/O模型: 1.  blocking ...

  6. windows2008r2防火墙设置一例

    有台dell R420服务器,系统windows2008r2 扫描出安全漏洞,按照默认开启防火墙,结果远程桌面上不去了,远程桌面端口号是10086,需要在 控制面板\所有控制面板项\Windows 防 ...

  7. DevExpress v19.1新版亮点——WinForms篇(四)

    行业领先的.NET界面控件DevExpress v19.1终于正式发布,本站将以连载的形式介绍各版本新增内容.在本系列文章中将为大家介绍DevExpress WinForms v19.1中新增的一些控 ...

  8. Flask【第9篇】:Flask-script组件

    flask-script组件 Flask Script扩展提供向Flask插入外部脚本的功能,包括运行一个开发用的服务器,一个定制的Python shell,设置数据库的脚本,cronjobs,及其他 ...

  9. 《Head First 软件开发》阅读二

    项目计划:为成功而筹划 每段伟大的代码始于伟大的计划. 客户现在就要他们的软件,可是开发需要的时间远远超过客户要求时间.我们需要实际解决方法:由客户确定优先级,与客户一起确定优先级顺序,开发出Mile ...

  10. electron打包成.exe后限制只启动一个应用

    注意:这是2.x的文档 const {app} = require('electron') let myWindow = null const shouldQuit = app.makeSingleI ...