创建和使用类
使用类几乎可以模拟任何东西。下面来编写一个表示小狗的简单类Dog——它表示的不是特定的小狗,而是任何小狗。
创建Dog类
根据Dog类创建的每个实例都将存储名字和年龄。我们赋予了每条小狗蹲下(sit( ))和打滚(roll-over( ))的能力:
Dog.py
class Dog():
"""一次模拟小狗的简单尝试"""
def __init__(self,name,age):
"""初始化name和age,init()左右下划线分别是两条"""
self.name=name
self.age=age
def sit(self):
"""模拟小狗被命令时蹲下"""
print(self.name.title()+" is now sitting.")
def roll_over(self):
"""模拟小狗被命令时打滚"""
print(self.name.title()+"roll over!")
根据约定,在Python中,首字母写的名称指的是类。这个类定义中的括号是空的,因为我们要从空白创建这个类。
1.方法__init__( )
唯一重要的区别是调用方法的方式。方法__init__( )是一个特殊的方法,每当你根据Dog类创建新实例时,Python都会自动运行它。在这个方法的名称中,开头和末尾各有两处下划线,这是一种约定,旨在避免Python默认方法与普通方法发生名称冲突。
我们将方法__init__( )定义成了包含三个形参:self 、name、和age。在这个方法的定义中,形参self必不可少,还必须位于其他形参的前面。为何必须在方法定义中包含形参self?因为Python调用这个__init__()方法来创建实例时,将自动传入实参self。每个与类相关联的方法调用都自动传递实参self,它是一个指向实例本身的引用,让实例能够访问类中方法和属性。我们创建Dog实例时,Python将调用Dog类的方法__init__( )。我们将通过实参向Dog( )传递名字和年龄;self会自动传递,因此我么不需要传递它。每当我们根据Dog类创建实例时,都只需给最后两个形参(name和age)提供值。
以self为前缀的变量都可供类中的所有方法使用,我么还可以通过类的任何实例来访问这些变量。self.name=name获取存储在形参name中的值,并将其存储到变量中,然后被变量关联到当前创建的实例。self.age=age作用与此类似。像这样可以通过实例访问的变量称为属性。
class Dog():
"""一次模拟小狗的简单尝试"""
def __init__(self,name,age):
"""初始化name和age"""
self.name=name
self.age=age
def sit(self):
"""模拟小狗被命令时蹲下"""
print(self.name.title()+" is now sitting.")
def roll_over(self):
"""模拟小狗被命令时打滚"""
print(self.name.title()+" roll over!")
my_dog=Dog('White',6)
his_dog=Dog('black',12)
print("My dog's name is "+my_dog.name.title()+".")
print("My dog is "+str(my_dog.age)+"years old.")
my_dog.sit()
print("\nhis dog's name is "+his_dog.name.title()+".")
print("His dog is "+str(his_dog.age)+"years old.")
his_dog.sit()
My dog's name is White.
My dog is 6years old.
White is now sitting.
his dog's name is Black.
His dog is 12years old.
Black is now sitting.
根据类创建实例
可将类视为如何创建实例的说明。Dog类是一系列说明,让Python知道如何创建表示特定小狗的实例。
my_dog=Dog('White',6)
print("My dog's name is "+my_dog.name.title()+".")
print("My dog is "+str(my_dog.age)+"years old.")
这里使用的是前一个示例中编写的Dog类。我们让Python创建一条名为‘while’、年龄为6的小狗。遇到这行代码时,Python使用实参‘while’和6调用Dog类中的方法__init__( )。方法__init__( )创建一个表示特定小狗的实例,并使用我们提供的值来设置属性name和age。方法__init__( )并未显示地包含return语句,但Python自动返回一个表示这条条狗的实例。我们将这个实例存储在my_dog中。在这里,命名约定很有用:我们通常可以认为首字母大写的名称(如Dog)指的是类,而小写名称(如my_dog)指的是实例。
1.访问属性
要访问实例中的属性,可使用句点表示法。我们编写了如下代码来访问my_dog的属性name的值:
my_dog.name
句点表示法很有用,这种语法演示了Python如何获悉属性的值。在这里,Python先找到实例my_dog,再查找与这个实例相关联的属性name。在Dog类中引用这个属性时,使用的是self.name。
调用方法
根据Dog类创建实例后,就可以使用句点表示法来调用Dog类中的方法。
my_dog.sit()
my_dog.roll_over()
3.创建多个实例
可根据需求类创建任意数量的实例。
my_dog=Dog('White',6)
his_dog=Dog('black',12)
使用类和实例
可以使用类来模拟现实生活中的许多场景。类编写好后,你的大部分时间都将花在使用根据类创建的实例上。你需要执行的一个重要任务是修改实例的属性,也可以编写方法在特定的类上进行修改。
Car类
下面来编写一个表示汽车的类,它存储了有关汽车的信息,还有一个汇总这些信息的方法:
class Car():
"""一次模拟汽车的简单尝试"""
def __init__(self,make,model,year):
"""初始化描述汽车的属性"""
self.make=make
self.model=model
self.year=year
def get_descriptive_name(self):
"""返回简洁的描述性信息"""
long_name=str(self.year)+' '+self.make+' '+self.model
return long_name.title()
my_new_car=Car('audi','a4','2016')
print(my_new_car.get_descriptive_name())
2016 Audi A4
我们定义了方法__init__( )。与前面的Dog类一样,这哥方法的第一个形参为self;我们还在这个方法中包含了另外三个形参:make、model、和year。方法__init__( )接受这些形参的值,并将它们存储在根据这个类创建的实例的属性中。
通过方法对属性的值进行修改
有时候需要将属性的值进行修改,现在我们将属性的值递增特定的量,假设我么购买了一辆二手车,且从购买到登记期间增加了100英里的里程,下面的方法让我们能够传递这个增量,并相应地增加里程表读数:
class Car():
"""一次模拟汽车的简单尝试"""
def __init__(self,make,model,year):
"""初始化描述汽车的属性"""
self.make=make
self.model=model
self.year=year
def get_descriptive_name(self):
"""返回简洁的描述性信息"""
long_name=str(self.year)+' '+self.make+' '+self.model
return long_name.title()
def update_odometer(self,mileage):
"""将里程表的读数设定为指定的值"""
self.odometer_reading=mileage
def increment_odometer(self,miles):
"""将里程表读数增加指定的量"""
self.odometer_reading+=miles
def read_odometer(self):
"""打印一条指出汽车里程的消息"""
print("This car has "+ str(self.odometer_reading)+" miles on it.")
my_used_car=Car('subaru','outback',2013)
print(my_used_car.get_descriptive_name())
my_used_car.update_odometer(23500)
my_used_car.read_odometer()
my_used_car.increment_odometer(100)
my_used_car.read_odometer()
2013 Subaru Outback
This car has 23500 miles on it.
This car has 23600 miles on it.
新增的方法increment_odometer()接受一个单位为英里的数字,并将其加入到self.odometer_reading中。我们创建了一辆二手车my_used_car。我们调用方法update_odometer( )并传入23500,将这辆二手车的里程表读数设置为23500。我们调用increment_odometer()并传入100,以增加从购买到登记期间行驶的100英里。