博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python_面向对象(其他)+异常处理+单实例
阅读量:5306 次
发布时间:2019-06-14

本文共 11212 字,大约阅读时间需要 37 分钟。

其他相关

一、isinstance(obj, cls)

 检查是否obj是否是类 Foo 的对象

class Foo(object):    pass obj = Foo() isinstance(obj, Foo)

检查n1是否由int方法转化

n1 =10print isinstance(n1,int) #结果:True

二、issubclass(sub, super)

检查sub类是否是 super 类的派生类

class Foo(object):    pass class Bar(Foo):    pass issubclass(Bar, Foo)

三、异常处理

1、异常基础

在编程过程中为了增加友好性,在程序出现bug时一般不会将错误信息显示给用户,而是现实一个提示的页面,通俗来说就是不让用户看见大黄页!!!

try:    passexcept Exception,e:    pass

如输入数字例子: 

while True:    try:        #正常执行部分        a = raw_input('Please input your number?')        print int(a)        break    except Exception,e:        #出现异常部分        print u'---错误信息如下!---'        #错误信息封装在e里,如有日志可以记录e进去        print e'''结果:Please input your number?jj---错误信息如下!---invalid literal for int() with base 10: 'jj'Please input your number?6666'''

 

2、异常种类

python中的异常种类非常多,每个异常专门用于处理某一项异常!!!

AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性xIOError 输入/输出异常;基本上是无法打开文件ImportError 无法引入模块或包;基本上是路径问题或名称错误IndentationError 语法错误(的子类) ;代码没有正确对齐IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5]KeyError 试图访问字典里不存在的键KeyboardInterrupt Ctrl+C被按下NameError 使用一个还未被赋予对象的变量SyntaxError Python代码非法,代码不能编译(个人认为这是语法错误,写错了)TypeError 传入对象类型与要求的不符合UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,导致你以为正在访问它ValueError 传入一个调用者不期望的值,即使值的类型是正确的
常用异常
ArithmeticErrorAssertionErrorAttributeErrorBaseExceptionBufferErrorBytesWarningDeprecationWarningEnvironmentErrorEOFErrorExceptionFloatingPointErrorFutureWarningGeneratorExitImportErrorImportWarningIndentationErrorIndexErrorIOErrorKeyboardInterruptKeyErrorLookupErrorMemoryErrorNameErrorNotImplementedErrorOSErrorOverflowErrorPendingDeprecationWarningReferenceErrorRuntimeErrorRuntimeWarningStandardErrorStopIterationSyntaxErrorSyntaxWarningSystemErrorSystemExitTabErrorTypeErrorUnboundLocalErrorUnicodeDecodeErrorUnicodeEncodeErrorUnicodeErrorUnicodeTranslateErrorUnicodeWarningUserWarningValueErrorWarningZeroDivisionError
更多异常
dic = ["wupeiqi", 'alex']try:    dic[10]except IndexError, e:    print e
IndexError
dic = {
'k1':'v1'}try: dic['k20']except KeyError, e: print e
实例:KeyError
s1 = 'hello'try:    int(s1)except ValueError, e:    print e
实例:ValueError

对于上述实例,异常类只能用来处理指定的异常情况,如果非指定异常则无法处理。

# 未捕获到异常,程序直接报错 s1 = 'hello'try:    int(s1)except IndexError,e:    print e

所以,写程序时需要考虑到try代码块中可能出现的任意异常,可以这样写:

s1 = 'hello'try:    int(s1)except IndexError,e:    print eexcept KeyError,e:    print eexcept ValueError,e:    print e

万能异常 在python的异常中,有一个万能异常:Exception,他可以捕获任意异常,即:

s1 = 'hello'try:    int(s1)except Exception,e:    print e

接下来你可能要问了,既然有这个万能异常,其他异常是不是就可以忽略了!

答:当然不是,对于特殊处理或提醒的异常需要先定义,最后定义Exception来确保程序正常运行。

s1 = 'hello'try:    int(s1)except KeyError,e:    print '键错误'except IndexError,e:    print '索引错误'except Exception, e:    print '错误'

3、异常其他结构

try:    # 主代码块    passexcept KeyError,e:    # 异常时,执行该块    passelse:    # 主代码块执行完,执行该块    passfinally:    # 无论异常与否,最终执行该块    pass

4、主动触发异常

try:    raise Exception('错误了。。。')except Exception,e:    print e

5、自定义异常

class Arror(Exception):    def __init__(self, msg):        self.message = msg    def __str__(self):        return self.messagetry:    #int('gg')    raise Arror('i error')except Arror,e:    print e

6、断言

# assert 条件 assert 1 == 1 assert 1 == 2

四、反射

python中的反射功能是由以下四个内置函数提供:hasattr、getattr、setattr、delattr,改四个函数分别用于对对象内部执行:检查是否含有某成员、获取成员、设置成员、删除成员。

class Foo(object):     def __init__(self):        self.name = 'wupeiqi'     def func(self):        return 'func' obj = Foo() # #### 检查是否含有成员 ####hasattr(obj, 'name')hasattr(obj, 'func') # #### 获取成员 ####getattr(obj, 'name')getattr(obj, 'func') # #### 设置成员 ####setattr(obj, 'age', 18)setattr(obj, 'show', lambda num: num + 1) # #### 删除成员 ####delattr(obj, 'name')delattr(obj, 'func')

 

 

详细解析:

当我们要访问一个对象的成员时,应该是这样操作:

class Foo(object):     def __init__(self):        self.name = 'alex'     def func(self):        return 'func' obj = Foo() # 访问字段obj.name# 执行方法obj.func()

        

那么问题来了?
a、上述访问对象成员的 name 和 func 是什么? 
答:是变量名
b、obj.xxx 是什么意思? 
答:obj.xxx 表示去obj中或类中寻找变量名 xxx,并获取对应内存地址中的内容。
c、需求:请使用其他方式获取obj对象中的name变量指向内存中的值 “alex”
class Foo(object):     def __init__(self):        self.name = 'alex' # 不允许使用 obj.nameobj = Foo()

答:有两种方式,如下:

class Foo(object):    def __init__(self):        self.name = 'alex'    def func(self):        return 'func'# 不允许使用 obj.nameobj = Foo()print obj.__dict__['name']
方式一
class Foo(object):    def __init__(self):        self.name = 'alex'    def func(self):        return 'func'# 不允许使用 obj.nameobj = Foo()print getattr(obj, 'name')
方式二

d、比较三种访问方式

  • obj.name
  • obj.__dict__['name']
  • getattr(obj, 'name')

答:第一种和其他种比,...

      第二种和第三种比,...

#!/usr/bin/env python#coding:utf-8from wsgiref.simple_server import make_serverclass Handler(object):    def index(self):        return 'index'    def news(self):        return 'news'def RunServer(environ, start_response):    start_response('200 OK', [('Content-Type', 'text/html')])    url = environ['PATH_INFO']    temp = url.split('/')[1]    obj = Handler()    is_exist = hasattr(obj, temp)    if is_exist:        func = getattr(obj, temp)        ret = func()        return ret    else:        return '404 not found'if __name__ == '__main__':    httpd = make_server('', 8001, RunServer)    print "Serving HTTP on port 8000..."    httpd.serve_forever()
Web框架实例

随写:

class Foo:    static_file = 'nba'    def __init__(self):        self.name = 'kobe'    def show(self):        pass    @staticmethod    def static_show():        pass    @classmethod    def class_show(cls):        passobj = Foo()print obj.__dict__print hasattr(obj,'name') #在对象里找#print hasattr(Foo,'static_show')  #在类里找print hasattr(obj,'show') #在对象没找到会到类里找

结论:反射是通过字符串的形式操作对象相关的成员。一切事物都是对象!!!

 

#!/usr/bin/env python# -*- coding:utf-8 -*-import sysdef s1():    print 's1'def s2():    print 's2'this_module = sys.modules[__name__]hasattr(this_module, 's1')getattr(this_module, 's2')
反射当前模块成员

 

类也是对象

class Foo(object):     staticField = "old boy"     def __init__(self):        self.name = 'wupeiqi'     def func(self):        return 'func'     @staticmethod    def bar():        return 'bar' print getattr(Foo, 'staticField')print getattr(Foo, 'func')print getattr(Foo, 'bar')

 

模块也是对象:

demo(模块对象):

import home #外来自写的home模块,里面有dev,h1,h2等函数print 'welcome my web!'url =  raw_input('input url: ')controller,action = url.split('/')#去home模块中检查是否含有指定的函数is_exist = hasattr(home,action)#如果存在指定的函数if is_exist: #获取函数 func = getattr(home,action) #执行函数并获取返回值 ret = func() print ret else: print '404 not found...'

 

动态式导入模块:

controller,action = raw_input('url: ').split('/')module = __import__(controller) #等同import XXX,并将xxx这个模块别名为module,如import xxx as modulefunc = getattr(module,action)ret = func()print ret

 

设计模式

一、单例模式

单例,顾名思义单个实例。

学习单例之前,首先来回顾下面向对象的内容:

python的面向对象由两个非常重要的两个“东西”组成:类、实例

面向对象场景一:

如:创建三个游戏人物,分别是:

  • 苍井井,女,18,初始战斗力1000
  • 东尼木木,男,20,初始战斗力1800
  • 波多多,女,19,初始战斗力2500
# #####################  定义类  #####################class Person:    def __init__(self, na, gen, age, fig):        self.name = na        self.gender = gen        self.age = age        self.fight =fig    def grassland(self):        """注释:草丛战斗,消耗200战斗力"""        self.fight = self.fight - 200# #####################  创建实例  #####################cang = Person('苍井井', '女', 18, 1000)    # 创建苍井井角色dong = Person('东尼木木', '男', 20, 1800)  # 创建东尼木木角色bo = Person('波多多', '女', 19, 2500)      # 创建波多多角色
View Code

面向对象场景二:

如:创建对数据库操作的公共类

# #### 定义类 ####class DbHelper(object):    def __init__(self):        self.hostname = '1.1.1.1'        self.port = 3306        self.password = 'pwd'        self.username = 'root'    def fetch(self):        # 连接数据库        # 拼接sql语句        # 操作        pass    def create(self):        # 连接数据库        # 拼接sql语句        # 操作        pass    def remove(self):        # 连接数据库        # 拼接sql语句        # 操作        pass    def modify(self):        # 连接数据库        # 拼接sql语句        # 操作        pass# #### 操作类 ####db = DbHelper()db.create()
View Code

实例:结合场景二实现Web应用程序

#!/usr/bin/env python#coding:utf-8from wsgiref.simple_server import make_serverclass DbHelper(object):    def __init__(self):        self.hostname = '1.1.1.1'        self.port = 3306        self.password = 'pwd'        self.username = 'root'    def fetch(self):        # 连接数据库        # 拼接sql语句        # 操作        return 'fetch'    def create(self):        # 连接数据库        # 拼接sql语句        # 操作        return 'create'    def remove(self):        # 连接数据库        # 拼接sql语句        # 操作        return 'remove'    def modify(self):        # 连接数据库        # 拼接sql语句        # 操作        return 'modify'class Handler(object):    def index(self):        # 创建对象        db = DbHelper()        db.fetch()        return 'index'    def news(self):        return 'news'def RunServer(environ, start_response):    start_response('200 OK', [('Content-Type', 'text/html')])    url = environ['PATH_INFO']    temp = url.split('/')[1]    obj = Handler()    is_exist = hasattr(obj, temp)    if is_exist:        func = getattr(obj, temp)        ret = func()        return ret    else:        return '404 not found'if __name__ == '__main__':    httpd = make_server('', 8001, RunServer)    print "Serving HTTP on port 8001..."    httpd.serve_forever()Web应用程序实例
View Code

对于上述实例,每个请求到来,都需要在内存里创建一个实例,再通过该实例执行指定的方法。

那么问题来了...如果并发量大的话,内存里就会存在非常多功能上一模一样的对象。存在这些对象肯定会消耗内存,对于这些功能相同的对象可以在内存中仅创建一个,需要时都去调用,也是极好的!!!

OK! 这时就是单例模式出马,单例模式用来保证内存中仅存在一个实例!!!

通过面向对象的特性,构造出单例模式:

# ########### 单例类定义 ###########class Foo(object):     __instance = None     @staticmethod    def singleton():        if Foo.__instance:            return Foo.__instance        else:            Foo.__instance = Foo()            return Foo.__instance # ########### 获取实例 ###########obj = Foo.singleton()

对于Python单例模式,创建对象时不能再直接使用:obj = Foo(),而应该调用特殊的方法:obj = Foo.singleton() ,测试时可用id察看内存是一样的,意味着调用的

是同一个对象并没有新开启新的对象空间

#!/usr/bin/env python#coding:utf-8from wsgiref.simple_server import make_server# ########### 单例类定义 ###########class DbHelper(object):    __instance = None    def __init__(self):        self.hostname = '1.1.1.1'        self.port = 3306        self.password = 'pwd'        self.username = 'root'    @staticmethod    def singleton():        if DbHelper.__instance:            return DbHelper.__instance        else:            DbHelper.__instance = DbHelper()            return DbHelper.__instance    def fetch(self):        # 连接数据库        # 拼接sql语句        # 操作        pass    def create(self):        # 连接数据库        # 拼接sql语句        # 操作        pass    def remove(self):        # 连接数据库        # 拼接sql语句        # 操作        pass    def modify(self):        # 连接数据库        # 拼接sql语句        # 操作        passclass Handler(object):    def index(self):        obj =  DbHelper.singleton()        print id(single)        obj.create()        return 'index'    def news(self):        return 'news'def RunServer(environ, start_response):    start_response('200 OK', [('Content-Type', 'text/html')])    url = environ['PATH_INFO']    temp = url.split('/')[1]    obj = Handler()    is_exist = hasattr(obj, temp)    if is_exist:        func = getattr(obj, temp)        ret = func()        return ret    else:        return '404 not found'if __name__ == '__main__':    httpd = make_server('', 8001, RunServer)    print "Serving HTTP on port 8001..."    httpd.serve_forever()
Web应用实例-单例模式

 

总结:单利模式存在的目的是保证当前内存中仅存在单个实例,避免内存浪费!!!

 

转载于:https://www.cnblogs.com/fengzaoye/p/5806240.html

你可能感兴趣的文章
beego 连接postgres
查看>>
监控系统状态
查看>>
delphi listbox 使用
查看>>
MySQL 数据库 -- 数据操作
查看>>
PHP 事件机制(2)
查看>>
[Bzoj1047][HAOI2007]理想的正方形(ST表)
查看>>
mysql导入hbase
查看>>
JavaScript中null和undefined的总结
查看>>
Python开发环境Spyder安装方法
查看>>
Web测试实践——每日例会记录12.30(2)
查看>>
Python内置函数(16)——ord
查看>>
USBIP --ubuntu 10.04(USB局域网共享)
查看>>
网络命令之 ss
查看>>
oracle 导入导出
查看>>
python之路,day6-面向对象
查看>>
Groovy中String转换Gstring用于动态插值
查看>>
查看dmesg,会打出很多的日志“TCP: too many of orphaned sockets”
查看>>
Oracle
查看>>
IT行业始接触
查看>>
Python基础知识点小结
查看>>