如何使用Python的类? 优势有哪些?

  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 () )

本作品采用《CC 协议》,转载必须注明作者和本文链接
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!