python--类属性的调用方法

发布时间:2019-09-10 09:18:10编辑:auto阅读(1404)

    测试时候类的调用是经常会用到的。简单看下类的调用使用的方法吧。

    来看例子:
    目录结构:
    python--类属性的调用方法

    我们现在要在do_class.py这个文件里调用class_learn.py里的类

    代码(do_class.py):

    #!/usr/bin/env python3
    #coding=utf-8
    '''@Author:Jock'''
    
    from all_python_learn.class_and_funcation.class_learn import *
    
    b = Learn(1,2)
    b.get()
    print(Learn.a)

    这里通过from导入了模块class_learn里的类,然后通过类的实例化实例了一个b的对象,然后通过对象b调用了类里的get函数。这里我加了个print(Learn.a)就是想说直接通过类名接上变量名可以调用类的变量。

    运行结果:
    python--类属性的调用方法

    如果我们不实例化直接调用会有什么结果呢?来看看

    修改do_class.py为:
    python--类属性的调用方法

    如果这么写那就报错了,因为没有实例化。

    报错:
    python--类属性的调用方法

    上面的例子是带传入参数的类,也可以有不带参数的类,然后被调用。

    把class_learn.py改成下面:
    python--类属性的调用方法

    在do_class.py就可以这么写:

    python--类属性的调用方法
    运行结果:

    python--类属性的调用方法

    通过上面的例子基本知道怎么去调用类里的函数、类里的变量了(这个非常重要,写用例时经常会跨文件去访问类里的属性!!)

    但我估计你们在看了上面代码后对self比较疑惑,其实开始类的定义时有讲过,这个是必须写的,是类的实例。

    例子里的初始化函数里的

    self.x=x #这里的x和y就是实例变量
    self.y=y

    这是定义了两个变量x和y,并赋给实例self.x和self.y,在后面的所有函数中如果要用到这个两个变量,都需要通过self.x的写法来调用,并且函数的参数列表必须带有self,并且把实例传了进去。否则调用就会报错。

关键字