python学习之路day07

本节内容:

  • 面向对象高级语法部分
    • 经典类vs新式类  
    • 静态方法、类方法、属性方法
    • 类的特殊方法
    • 反射
  • 异常处理
  • Socket开发基础
  • 作业:开发一个支持多用户在线的FTP程序

classical vs new style:

  • 经典类:深度优先
  • 新式类:广度优先
  • super()用法

    class Foo(object):
                def __init__(self,name,age,sex,salary,course):

                    self.salary = salary
                    self.course = course

注:2.7 经典类,深度优先,  新式类,广度优先
        3.x 均是广度优先

静态方法(只是名义上归类管理, 实际上在静态方法里访问不了类或实例中的任何属性)

通过@staticmethod装饰器即可把其装饰的方法变为一个静态方法,什么是静态方法呢?其实不难理解,普通的方法,可以在实例化后直接调用,并且在方法里可以通过self.调用实例变量或类变量,但静态方法是不可以访问实例变量或类变量的,一个不能访问实例变量和类变量的方法,其实相当于跟类本身已经没什么关系了,它与类唯一的关联就是需要通过类名来调用这个方法

class Dog( object ):
     def __init__( self ,name):
         self .name = name
     @staticmethod #把eat方法变为静态方法
     def eat( self ):
         print ( "%s is eating" % self .name)
d = Dog( "ChenRonghua" )
d.eat(d)#调用时主动传递实例本身给eat方法,即d.eat(d) 

类方法(只能访问类变量,不能访问实例变量)

类方法通过@classmethod装饰器实现,类方法和普通方法的区别是, 类方法只能访问类变量,不能访问实例变量

class Dog( object ):
name="我是类变量"
     def __init__( self ,name):
         self .name = name
 
     @classmethod
     def eat( self ):
         print ( "%s is eating" % self .name)
d = Dog( "ChenRonghua" )
d.eat()

属性方法(把一个方法变成一个静态属性)

属性方法的作用就是通过@property把一个方法变成一个静态属性

class Dog( object ):
 
     def __init__( self ,name):
         self .name = name
 
     @property
     def eat( self ):
         print ( " %s is eating" % self .name)
 
d = Dog( "ChenRonghua" )
d.eat   #不加()

类的特殊成员方法

1. __doc__  表示类的描述信息

class Foo:
     """ 描述类信息,这是用于看片的神奇 """
 
     def func( self ):
         pass
 
print ( Foo.__doc__)

2. __module__ 和  __class__ 

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

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

class C:

     def __init__(self):

            self.name = 'wupeiqi'

from lib.aa import C

obj = C()

print (obj.__module__)  # 输出 lib.aa,即:输出模块
print (obj.__class__ )     # 输出 lib.aa.C,即:输出类

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

4.__del__

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

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

反射

通过字符串映射或修改程序运行时的状态、属性、方法, 有以下4个方法:hasattr、getattr、setattr

    hasattr(obj,name_str) , 判断一个对象obj里是否有对应的name_str字符串的方法
    getattr(obj,name_str), 根据字符串去获取obj对象里的对应的方法的内存地址
    setattr(obj,'y',z), is equivalent to ``x.y = v''
    delattr

代码示例:

def bulk(self):
    print("%s is yelling...." %self.name)

class Dog(object):
    def __init__(self,name):
        self.name = name

    def eat(self,food):
        print("%s is eating..."%(self.name,food))


d = Dog("NiuHanYang")
choice = input(">>:").strip()

if hasattr(d,choice):
    getattr(d,choice)
else:
    setattr(d,choice,bulk) #d.talk = bulk
    func = getattr(d, choice)
    func(d)

动态导入模块

import importlib
__import__ ( 'import_lib.metaclass' ) #这是解释器自己内部用的
importlib.import_module('import_lib.metaclass') #与上面这句效果一样,官方建议用这个

异常处理 

1.异常的格式
    try :
        code
    except (Error1,Erro2) as e:
        print e

    except Exception :抓住所有错误,不建议用

参考 http://www.cnblogs.com/wupeiqi/articles/5017742.html   

2.异常种类

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

AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x

IOError 输入/输出异常;基本上是无法打开文件

ImportError 无法引入模块或包;基本上是路径问题或名称错误

IndentationError 语法错误(的子类) ;代码没有正确对齐 IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5]

KeyError 试图访问字典里不存在的键

KeyboardInterrupt Ctrl+C被按下

NameError 使用一个还未被赋予对象的变量

SyntaxError Python代码非法,代码不能编译(个人认为这是语法错误,写错了)

TypeError 传入对象类型与要求的不符合

UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量, 导致你以为正在访问它

ValueError 传入一个调用者不期望的值,即使值的类型是正确的

代码示例:

class Dog(object):
    def __init__(self,name):
        self.name = name

    def eat(self,food):
        print("%s is eating..."%self.name,food)

names = ['alex','jack']
try:
    open("tes.txt")

except (KeyError,IndexError) as e :
    print("没有这个key",e)
except IndexError as e :
    print("列表操作错误",e)
except BaseException as e:
    print("未知错误",e)
else:
    print("一切正常")
finally:
    print("不管有没有错,都执行")

Socket 编程

参考:http://www.cnblogs.com/wupeiqi/articles/5040823.html

猜你喜欢

转载自www.cnblogs.com/0818and0119/p/10060213.html