class Car:
def __init__(self, make, model, year):
self.make = make
self.model = model
self.year = year
self.odometer_reading = 0
def get_descriptive_name(self):
long_name = f"{self.year} {self.make} {self.model}"
return long_name.title()
def read_odometer(self):
print(f"This car has {self.odometer_reading} miles on it.")
def update_odometer(self, mileage):
if mileage >= self.odometer_reading:
self.odometer_reading = mileage
else:
print("You can't roll back on odometer!")
def increment_odometer(self, miles):
self.odometer_reading += miles
class Battery:
def __init__(self, battery_size=75):
self.battery_size = battery_size
def describe_battery(self):
print(f"This car has a {self.battery_size}-kWh battery.")
class ElectricCar(Car):
def __init__(self, make, model, year):
super().__init__(make, model, year)
self.battery = Battery()
my_tesla = ElectricCar('tesla', 'model s', 2019)
print(my_tesla.get_descriptive_name())
my_tesla.battery.describe_battery()
如果要在最后输出的my_tesla.battery.describe_battery()不显示默认值,而是更改后的参数值,该怎样去传入新的Battery类中包含的battery_size参数呢?我个人思路是在Battery类中新增一个修改的参数用的方法,在最后输出前执行一下修改的方法,再执行最后的输出结果,不知道这样正确不?
你的思路是可以的,如果battery_size是需要频繁修改的话就增加一个修改的方法,如果一开始实例化 ElectricCar的时候就是固定不变的话,可以直接初始化self.battery = Battery(battery_size)。
另一种思路就是采用多继承:
class ElectricCar(Car, Battery):
def __init__(self, make, model, year, battery_size=75):
Car.__init__(self, make, model, year)
Battery.__init__(self, battery_size)
要么是battery继承electric car的值,要么你就搞得复杂点,多写几个函数