复习

class 类名(父类,父类2):
静态属性 = '' #静态属性 类属性
def __init__(self): #初始化方法
self.name = 'alex'
def func(self):
print(self,age) #动态属性 方法
对象 = 类名()
对象.方法名()
对象.属性名
对象.name
对象.age = 18
对象.func()
组合:表达的是什么有什么 *****
一个类的属性是另外一个类的对象
命名空间:类和对象分别存在不同的命名空间中
面向对象的三大特性:继承、多态、封装
继承:单继承 :****
父类(超类、基类)
子类(派生类):派生方法和派生属性,
子类的对象在调用方法和属性:先用自己的,自己没有才用父类的
多继承:***(面试)
不会超过三个父类,不要超过三层 ***
如果子类自己有用自己的,如果没有就用离子类最近的那个父类的方法
抽象类和接口类**
经典类和新式类:继承规则不同,深度优先和广度优先 *****(面试)
super 只能在python3中使用 ****
super是根据mro广度优先顺序找上一个类
多态 ***:(面试)
多态和鸭子类
封装:(面试)
私有的 __名字
只能在类的内部调用,子类都无法继承
三个装饰器
@property ****
@staticmethod ***
@classmethod *****当一个方法只使用了类的静态变量时,就给这个方法加上@classmethod装饰器,默认传cls参数

'''
class Teacher:
pass
class Course:
def __init__(self,name,price,period):
self.name = name
self.price = price
self.period = period
python = Course('python',19800,'6 months')
class Classes:
def __init__(self,name,course,teacher,school):
self.name = name
self.course = course
self.teacher = teacher
self.school = school
pys9 = Classes('pytho_s9',python,'tim','oldboy')
print(pys9.course.name)
python.name = 'python全栈'
print(pys9.course.name)
# isinstance和issubclass
# isinstance(obj,cls)检查是否obj是否是类 cls 的对象
# class A:
# pass
# a = A()
# print(isinstance(a,A))
# issubclass(sub, super)检查sub类是否是 super 类的派生类
# class A:
# pass
# class B(A):pass
# a = A()
# print(issubclass(B,A))
# 反射:是用字符串类型的名字去操作变量
# 反射就没有安全问题
# 反射对象中的属性和方法 hasattr getattr setattr delatter
# class A:
# def func(self):
# print('in func')
# a = A()
# a.name = 'alex'
# a.age = 64
# 反射对象的属性
# ret = getattr(a,'name') #通过变量名的字符串形式取到的值
# get = input('>>>>>>')
# print(getattr(a,get))
# print(a.__dict__[get])
# 反射对象里的方法
# ret = getattr(a,'func')
# ret()

class A:
price = 20
def func(self):
print('in func') # 反射类的属性
print(getattr(A,'price'))
# 反射类的方法:classmethod  staticmethod
# 类名.方法名
class A:
price = 20
@classmethod
def func(cls):
print('in func')
print(getattr(A,'func'))
ret = getattr(A,'func')
ret()
# 模块
# 反射模块的属性
import my
# print(my.day)
print(getattr(my,'day')) # 反射模块的方法
ret = getattr(my,'wahaha')
ret()
# 反射自己的模块中的变量
# year = 2019
# import sys
# print(sys.modules['__main__'])
# def qqxing():
# print('qqxing')
# print(getattr(sys.modules['__main__'],'year')) # 反射自己模块中的方法或函数
# print(getattr(sys.modules['__main__'],'qqxing'))
# ret = getattr(sys.modules['__main__'],'qqxing')
# ret()
#
# get = input('>>>>>>> ')
# print(getattr(sys.modules['__main__'],get))
# print(getattr(sys.modules[__name__],get))
# 一个模块中的类能不能反射的到
# import my
# print(getattr(my,'C')())
# if hasattr(my,'name'):
# getattr(my,'name')
# setattr() 设置修改变量
class A:
pass
a = A()
setattr(A,'name','tim')
setattr(a,'name','gim')
print(A.name)
print(a.name)
# delattr()删除一个变量
delattr(a,'name')
print(a.name)
# obj.__str__

# 内置的类方法和内置的函数之间有着千丝万缕的联系
class Teacher:
def __init__(self,name,salary):
self.name = name
self.salary = salary
def __str__(self):
return "Teacher's object : %s"%self.name
# a = A()
nezha = Teacher('哪吒',250)
print(nezha)
# print(a) #打印一个对象的时候,就是调用a.__str__
# object 有个双下str,一旦被调用,就返回调用这个方法的内存地址
# print('%s:%s'%('A',a)) #%s str() 直接打印 实际上都是走__str__
Teacher's object : 哪吒
# %s str()  直接打印  实际都是走__str__
# %r repr() 直接打印 实际都是走__repr__ repr是str的备胎,反过来不行
# obj.__repr__
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__)
# a = A()
nezha = Teacher('哪吒',250)
print(nezha)
print(repr(nezha))
print('>>>>>%r'%nezha)
# %s str()  直接打印  实际都是走__str__
# %r repr() 直接打印 实际都是走__repr__ repr是str的备胎,反过来不行(str不能做repr的备胎)
#str(obj)的时候,实际上是内部调用了obj.__str__方法,如果str方法有返回值,那么他返回的必定是一个字符串
#如果没有__str__方法,会先找本类中的__repr__方法,在没有再找父类中的__str__
# __del__
class A:
def __del__(self):
print('执行我拉')
a = A()
del a #del 既执行了这个方法,又删除了变量,
print(a)
# __call__
class A:
def __init__(self,name):
pass
def __call__(self):
print('执行我了')
a = A('tim')
a() #相当于执行了__call__方法
												

Python9-反射-day27(大年初三)的更多相关文章

  1. day27:异常&反射

    目录 认识异常处理 1.程序错误的种类    2.异常的分类 3.AssertionError(断言assert语句失败) 异常处理的基本语法 1.异常处理的基本语法 2.带有分支的异常处理 3.处理 ...

  2. day27:反射和双下方法

    1, # 面向对象的三大特性:继承,多态和封装 # 继承: # 单继承: **** # 父类(超类,基类) # 子类(派生类) 派生方法和派生属性 # 子类的对象在调用方法和属性:先用自己的,自己没有 ...

  3. day27(反射之内省机制)

    内省 内省:底层是使用反射机制实现的,是对于反射的进一步封装. 反射:通过类名来获取类中的所有属性和方法及类中的所有隐藏的方法. 内省:通过一个标准类(javabean类)来获取bean中的字段.ge ...

  4. day27<反射&JDK5新特性>

    反射(类的加载概述和加载时机) 反射(类加载器的概述和分类) 反射(反射概述) 反射(Class.forName()读取配置文件举例) 反射(通过反射获取带参构造方法并使用) 反射(通过反射获取成员变 ...

  5. day27(反射之内省机制实现BeanUtils)

    使用内省方式来实现beanUtils往对象里面存值 public class BeanInfoUtil2 { public static void setPropertyByIntrospector( ...

  6. day27

    27.01 反射(类的加载概述和加载时机) 1.类的加载 当程序要使用某个类时,如果该类还未加载到内存中,系统会通知加载,连接,初始化三步来实现对这个类初始化 a.加载 是指将.class文件读入内存 ...

  7. python 反射和内置方法

    一.isinstance和issubclass class Foo: pass class Son(Foo): pass s = Son() #判断一个对象是不是这个类的对象,传两个参数(对象,类) ...

  8. Python进阶-XVIII 封装、(属性、静态方法、类方法)语法糖、反射

    1.封装 类中的私有化:属性的私有化和方法的私有化 会用到私有的这个概念de场景 1.隐藏起一个属性 不想让类的外部调用 2.我想保护这个属性,不想让属性随意被改变 3.我想保护这个属性,不被子类继承 ...

  9. 隐私泄露杀手锏 —— Flash 权限反射

    [简版:http://weibo.com/p/1001603881940380956046] 前言 一直以为该风险早已被重视,但最近无意中发现,仍有不少网站存在该缺陷,其中不乏一些常用的邮箱.社交网站 ...

随机推荐

  1. C#基础之析构函数

  2. Codeforces Round #533(Div. 2) A.Salem and Sticks

    链接:https://codeforces.com/contest/1105/problem/A 题意: 给n个数,找到一个数t使i(1-n)∑|ai-t| 最小. ai-t 差距1 以内都满足 思路 ...

  3. vs2013缺少Mvc 怎么办?

    命名空间System.Web中不存在类型或命名空间名称Mvc是否缺少程序集引用? 以前vs2010或2012以前的引用一下就有了,为何现在vs2013没有,该这么处理呢?? 解决方案: 打开PCM:  ...

  4. 解决windows下 Python中 matplotlib 做图中文不显示的问题

    在代码中填入以下两句即可 from pylab import mpl mpl.rcParams['font.sans-serif'] = [font_name] 如:mpl.rcParams['fon ...

  5. python学习之列表元组,字典

    list:元素性质可以不一致,元素还可以是list,可类似数组方法进行索引(也可以用负数索引,-1表示最后一个),可用.append('')进行动态增加,可用pop()删除最后一个或者pop(i)删除 ...

  6. css3のborder-radius

    css3のborder-radius 今天主要练习了一下border-radius这个属性,这个是最常用的属性,所以先从它开始学习和总结吧. 我觉得需要注意以下几点: 1.书写规范: -webkit- ...

  7. AJPFX总结hashmap和hashtable的区别

    Hashtable和HashMap类有三个重要的不同之处.第一个不同主要是历史原因.Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现. ...

  8. C语言abort函数

    C语言编程入门教程,C语言库函数的abort函数的作用是异常终止一个进程,意味着abort后面的代码将不再执行. #include<stdio.h> #include<stdlib. ...

  9. IOS命名

    NS开头的名称不要出现. NS系统名称开头. 命名缩写只用于通用专业术语,如URL,不可自创命名缩写,如Ctr.Msg.命名宁可长一些,也不要难于理解. 是否在看别人代码时各种缩写而不知其所以然?简短 ...

  10. asp.net 页面嵌套(非iframe)方法

    前台 <div id="divUrlDetail" runat="server"> </div> 后台 protected void P ...