为什么使用Python? 优势有哪些?

时间:2020-8-2 作者:admin


Python 是一种面向对象的高级语言,因此类对于 Python 非常重要。类是一个空间,在该空间中变量 (属性 / 方法) 分别存储。运算符’ . ‘用于调用类的属性和方法。类是事务类的抽象,它不是真的存在,它描述了事务的共性。在搜索类属性时,python 首先找到实例,然后在实例中找到属性,当找不到时,它将在类内部进行搜索。那么如何使用 Python 的类?优势有哪些?下面让我们一起来详细了解一下吧。

如何使用 Python 的类?

1. 在 Python 中,定义类是通过 class 关键字来实现的:

class Student(object):

Pass

class 后面紧接着是类名,即 Student. 类名通常采用单词首字母大写的形式命名,比如 StudentCore。

(object) 表示该类是从哪个类继承来的。如果没有合适的继承类,则通常使用 object 类,这是所有类都会继承的类。

2. 实例化一个类是通过在类名后面加小括号 “()” 来实现的:

pupil=Student ()

“小学生” 是 “学生” 这个的一个实例。所谓实例,可以将其理解为类的化身。类不能被直接使用,只能先将其实例化,然后用实例代表类,进而调用类中的方法处理数据。那么实例是怎么代表类的呢?在定义类及其方法时,有一个参数叫 self, 它就是串联实例与类之间的关键参数,可以简单地理解为 “self = 实例名”。

类的下面有属性和方法。可以将属性理解为静态的数据,将方法理解为动态的处理函数。比如,在下面的代码中定义了 “学生” 类,其中_ init _是属性,print_score 是方法。

#–coding:utf-8-

Class Student (object) :

def _ _ init_ _ (self,name,score) :

self.name= name

self.score=score

def print_score (self) :

print (‘%s: %s’% (self. _ _name,self. _ _acore) )

3. 实例化上面的类,然后分析 Python 如何利用实例化类调用类中的方法。

完整的实例化类与调用过程如下:

pupil=student (name=’lilei’,score=99)

pupil.print_score ()

按照前面的说法,self = 实例名,那么 pupil=Student (name=’lilei’,score=99) , 实例化类的第一步是执行 _ init _ 语句,即 Student (self=’pupil’,name=’lilei’,score=99) , 则可知 pupil.name=’lilei’,pupil.score=9. 实例化类的第二步是执行 pupil.print_score () 语句,调用实例的方法就是调用类的方法,而这个方法是按照格式打印出

pupil.name:pupil.score,mlilei: 99。

Python 类优势有哪些?

1. 类的访问限制

所谓类的访问限制,即在类的外部不能直接调用类中的数据。在 Python 中,在变量前加 “_ _” 可将变量置为私有变量,使其只能在类中被使用,不能被类之外的其他函数 (方法) 调用。下面代码中的 name 参数表示的就是私有变量。

#–coding:utf-8–

#_ author _=’大婶 N72’

class Student (object) :

def _ init _(self,name,score) :

self._ _name= name

self.score= score

def print_score (self) :

print (‘%s: %S’% (self._ name,self. _score) )

MeiMei=Student (‘hello’, 99)

print (MeiMei.score)

print (MeiMei. _ _name)

代码的运行结果很好地佐证了加了 “_ ” 的参数是不能被调用的,没加 “ _” 的参数是可以直接被调用的,如下所示:

C:\Python36\python3. exe F:/Autotest_interface_demo/test. py www.zpedu.com/it/rjyf/

99

Traceback (most recent call last):

File “F:/Autotest interface demo/test.py”, line 12, in

print (MeiMei._name)

AttributeError: ‘ Student’ object has no attribute’__name’

Process finished with exit code 1

2. 类的继承

所谓 “继承”, 从字面上看很好理解:如果一个类继承了另外一个类,则这个类就有了被继承的类的所有方法和属性。我们可以直接使用这些方法和属性,无须再单独写。下面举一个例子来解释什么是继承。类的基本定义如下:

# – coding:utf-8 –

# _ author _=‘大婶 N72’

# 父类

class Parent (object) :

def print_self (self) :

return “我是父类”

# 子类继承父类

class Student (Parent) :

def_ init _ (self,name,score) :

self. _ _name= name

self.score=score

def print_score (self) :

print (‘%s: %s’% (self. _ _name,self. _ _score) )

MeiMei=Student (‘hello’, 99)

print (MeiMei.score)

# 直接在子类中使用父类的方法

print (MeiMei.print_self ()

在上面的例子中,子类 Student 继承了父类 Parent. 方法是在类名称后面的小括号中加上父类的名称。子类继承了父类,则有了父类 Parent 的方法 print_self, 从而可以直接在自己的实例名中使用。

3. 类的多态

如果子类继承了父类,但是又想改变父类的方法,则这时无须修改父类的方法,只需要在子类中添加相同的方法名就可以起到覆盖的作用,这就是多态。

# – coding:utf-8 –

# _ author _=’大婶 N72’

# 父类

class Parent (object) :

def print_self (self) :

return” 我是父类”

# 子类继承父类

class Student (Parent) :

def _ init _ (self,name,score) :

self. _ _name= name

self.score=score

def print_score (self) :

print (‘%s: %S’% (self. _name,self. _ _score) )

def print_self (self) :

return” 我是子类”

MeiMei=Student (‘hello’, 99)

print (MeiMei.score)

# 子类的方法覆盖父类方法

print (MeiMei.print_self () )

声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。