面向对象,春暖花开

面向对象编程语言

类:一个模板(人类),抽象的,没有具体的

对象:(具体存在的,eg:张三,李四)

属性:表示这类东西的特征:鼻子,眼睛,嘴巴

方法:表示这类物体能做的事情:吃饭,睡觉,学习

1). 定义类:class:from collections import  Counter
 例子: str, list, dict, Counter(内置的)
 object代表是, 人类继承于哪一个类, 如果不知道继承哪个类, 就写object;
class 人类(object):
    # print('hello')
    # 构造方法(魔术方法), 当创建对象的时候(有实例化对象), 自动执行的函数
    def __init__(self, name, age, gender):
        # python解释器自动将对象传给self这个形参.
        # 看self到底是什么东西?
        # 将对象与该对象的属性绑定在一起.
        #  调用对象的属性两种方式:
        #       - 张三.name
        #       - self.name
        self.name = name     # 属性
        self.age = age       # 属性
        self.gender = gender # 属性
        print(self)   # 实质上是一个对象, <__main__.人类 object at 0x7f4fdc4864a8>

    # 方法(在类里面定义的函数, 叫做方法)
    def eat(self):
        print("%s 正在吃饭..." %(self.name))

 #创建对象====根据模板(类)创建对象(真实存在)
张三 = 人类("张三",  10, 'male')

 #看对象的属性
print(张三.name)
print(张三.age)
print(张三.gender)

 #让对象执行方法
张三.eat()

类的私有属性和私有方法

类的私有属性:

__private_attrs:两个下划线开头,声明该属性为私有,不能在类地外部被使用或直接访问。 在类内部的方法中使用时 self.__private_attrs

类的方法:

在类的内部,使用 def 关键字来定义一个方法,与一般函数定义不同,
类方法必须包含参数 self,且为第一个参数,self 代表的是类的实例。
self 的名字并不是规定死的(因为是形参),也可以使用 this,但是最好还是按照约定是用 self。

类的私有方法

__private_method:两个下划线开头,声明该方法为私有方法,只能在类的内部调用 , 不能在类的外部调用 self.__private_methods
class People(object):
    def __init__(self,name,age,gender, money):
        self.name = name
        self.age = age
        self.gender = gender
        self.__money = money
    def __play(self):
        print("王者荣耀正在进行时......")

向杰 = People('向杰', 10, 'male', 1000000)
print(向杰.gender)

应用:栈的数据结构

栈的方法:

入栈(push), 出栈(pop), 栈顶元素(top),
栈的长度(length), 判断栈是否为空(isempty)
显示栈元素(view)
操作:入栈2次 ,出栈1次 ,显示最终栈元素
class Stack(object):
    # 构造函数
    def __init__(self):
        self.stack = [ ]
    def push(self, value):
        self.stack.append(value)
        return True   
    def pop(self):
        # 判断栈是否为空
        if self.stack:
            # 获取出栈元素, 并返回
            item = self.stack.pop()
            return  item
        else:
            return  False
    def top(self):
        if self.stack:
            return  self.stack[-1]
        else:
            return  False
    def length(self):
        return  len(self.stack)
    def isempty(self):
        return self.stack==[]
    def view(self):
        return  ",".join(self.stack)

s = Stack()
s.push('1')
s.push('2')
s.push('3')
s.push('4')
item = s.pop()
print(s.view())

面向对象的反射机制

1.如果知道对象拥有的属性和方法.

 print(dir(str))
 f=open('/tmp/passwd')
 print(dir(f))

2.判断对象所属的类

print(type('hello'))
class Student(object):
    """
    这是Student类的帮助文档
    """
    def __init__(self,name,age):
        self.name=name
        self.age=age
    def get_score(self):
        return 'score'
    def get_grade(self):
        return 'grade'
s1=Student('lijia',20)
print(type(s1))
print(isinstance(s1,Student))
print(isinstance('lijia',Student))

3.根据对象可以获取的内容

print(s1.__class__)
print(s1.__dict__)
print(s1.__doc__)

4.hasattr,getattr,setattr,delattr

hasattr:判断对象是否包含对应的属性或者方法名
 print(hasattr(s1,'name'))
 print(hasattr(s1,'__age')) #私有属性和私有方法不能判断
 print(hasattr(s1,'score'))
 print(hasattr(s1,'get_score'))
 print(hasattr(s1,'set_score'))
getattr:用于返回对象的属性值或者方法名对应的方法体
print(getattr(s1,'name'))
print(getattr(s1,'__age','no attr'))
print(getattr(s1,'get_score','no method'))#获取方法名,如果要执行,直接调用即可
print(s1,'set_score','no method')
setattr:修改某个属性的值
setattr(s1,'name','westos')
print(getattr(s1,'name'))
添加某个属性及对应的值
setattr(s1,'score',90)
print(getattr(s1,'score'))
修改方法
def get_score1():
    return '这是修改的方法内容'
setattr(s1,'get_score','get_score1')
print(getattr(s1,'get_score'))

def set_score():
    return '这是添加的方法'
添加方法
setattr(s1,'set_score',set_score)
print(getattr(s1,'set_score'))
print(getattr(s1,'set_score')())
delattr
delattr(s1,'name')
print(hasattr(s1,'name'))
print(hasattr(s1,'set_score'))
delattr(s1,'set_score')
print(hasattr(s1,'set_score'))

反射机制的应用场景

class Web(object):
    def newarticles(self):
        return '<h1>newarticles</h1>'
    def watchers(self):
        return '<h1>watchers</h1>'
    def news(self):
        return '<h1>news</h1>'
    def ai(self):
        return '<h1>ai</h1>'
flask=Web()
def run():
    url=input('url:')
    # if url=='news':
    #     return flask.news()
    # elif url=='ai':
    #     return flask.ai()
    # else:
    #     return '<h1>404<h1>'
    #如果方法多的话,以上方法比较麻烦,以下操作比较简单
    if hasattr(flask,url):
        return getattr(flask,url)()
    else:
        return '<h1>404</h1>'
if __name__=='__main__':
    while True:
        print(run())
 ```
##反射机制与动态导入

def run():
#’/bbs/index’; modules=’bbs, func=’index’
modules,func=input(‘url:’).split(‘/’)[-2:]
#导入一个包含变量的模块名,其中obj是模块的别名
obj=import(‘lib.’+module)
# 判断模块中是否有指定的方法, 如果有, 则执行代码, 如果没有, 404报错;
print(obj)
print(modules)
print(obj.index())

if hasattr(obj, func):
    fun = getattr(obj, func)
    return fun()
else:
    return "404: 页面找不到"

    import lib.bbs
    import lib.bbs as obj
    obj.index()
    lib.bbs.index()
    if hasattr(flask, url):
        return getattr(flask, url)()
    else:
        return "<h1>404</h1>"

if name == “main“:
while True:
print(run())
“`

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值