前言
这一段代码帮助搬家的用户更好的规划空间和家中物品。他通过用户输入房子的面积和家具的大小来判断,在保证舒适的情况下,是否能够装下输入的家具。若能装下,返回房子中现有的家具名和房子剩下的面积。若无法装下某个物件,则不把该物件名包括在家具名中。(大家可以后期通过添加偏好来在房子面积不足时保留想要的家具)
一、代码展示
class Funiture():#家具
def __init__(self, area, name):#定义家具的基本特征
self.area = area
self.name = name
class House():#房子
def __init__(self, house_area, loc_house, free_area):#定义房子的基本特征
self.area = house_area
self.loc = loc_house
self.free = free_area
self.funiture = []
def __str__(self):#魔法方法,不论是否调用该函数他都会显示出来
return f"the house is in {self.loc}. \
Area of the house is:{self.area}㎡. \
Free area now is {self.free}㎡. \
It contains {self.funiture}"
def decorate(self, items):#家具放置-放一次家具,剩余面积会自减该家具的占用面积
if self.free >= items.area*2:
self.funiture.append(items.name)#将家具放入房子里
self.free-=items.area
else:
print(f"too big to accept {items.name}")
house=House(40,"Yorkshare",40)#实例化对象
lst=[]
for i in list(map(chr,range(97,123))):
locals()[i]=0#将字符串转成变量,给它赋值0
lst.append(i)
print("use comma to separate items")
obj=input("add funiture to the house:").split(",")
size = [float(i) for i in input("enter the size:").split(",")]
for j in range(len(size)):
lst[j]=Funiture(size[j],obj[j])#聪明地用循环实例化输入的家具
house.decorate(lst[j])
print(house)