Solucionado (ver solução)
Solucionado
(ver solução)
1
resposta

Projeto [mão na massa]

sobremesa.py

from modelos.cardapio.item_cardapio import ItemCardapio

class SobreMesa(ItemCardapio):
    def __init__(self,nome,preco,tipo,tamanho,descricao):
        super().__init__(nome,preco)
        self.tipo = tipo
        self.tamanho = tamanho
        self.descricao = descricao

    def __str__(self):
        return self._nome 

    def aplicar_desconto(self):
        self._preco -= (self._preco * 0.15)   

restaurante.py

from modelos.avaliacao import Avaliacao
from modelos.cardapio.item_cardapio import ItemCardapio


class Restaurante:
    restaurantes = []

    def __init__(self, nome, categoria):
        self._nome = nome.title()
        self._categoria = categoria.upper()
        self._ativo = False
        self._avaliacao = []
        self._cardapio = []
        self._sobremesa = []
        Restaurante.restaurantes.append(self)
    
    def __str__(self):
        return f'{self._nome} | {self._categoria}'
    
    @classmethod
    def listar_restaurantes(cls):
        print(f'{'Nome do restaurante'.ljust(25)} | {'Categoria'.ljust(25)} | {'Avaliação'.ljust(25)} |{'Status'}')
        for restaurante in cls.restaurantes:
            print(f'{restaurante._nome.ljust(25)} | {restaurante._categoria.ljust(25)} | {str(restaurante.media_avaliacoes).ljust(25)} |{restaurante.ativo}')

    @property
    def ativo(self):
        return '⌧' if self._ativo else '☐'
    
    def alternar_estado(self):
        self._ativo = not self._ativo

    def receber_avaliacao(self, cliente, nota):
        if 0 < nota <= 5: 
            avaliacao = Avaliacao(cliente, nota)
            self._avaliacao.append(avaliacao)

    @property
    def media_avaliacoes(self):
        if not self._avaliacao:
            return '-'
        soma_das_notas = sum(avaliacao._nota for avaliacao in self._avaliacao)
        quantidade_de_notas = len(self._avaliacao)
        media = round(soma_das_notas / quantidade_de_notas, 1)
        return media  

    def adicionar_no_cardapio(self,item):
        if isinstance(item,ItemCardapio):
            self._cardapio.append(item)

    @property
    def exibir_cardapio(self):        
        print(f'Cardapio do restaurante {self._nome}\n')
        for i,item in enumerate(self._cardapio,start=1):
            if hasattr(item,'descricao'):
                mensagem_prato = f'{i}. Nome: {item._nome} | Preço: R${item._preco} | Descricao: {item.descricao}'
                print(mensagem_prato)
            elif hasattr:    
                mensagem_bebida = f'{i}. Nome: {item._nome} | Preço: R${item._preco} | Tamanho: {item.tamanho}'
                print(mensagem_bebida)
            else:
                mensagem_sobremesa = f'{i}. Nome: {item._nome} | Preço: R${item_preco} | Tipo: {item.tipo} | Tamanho: {item.tamanho}| Item: {item.descricao}'    
                print(mensagem_sobremesa)
        

app.py

from modelos.restaurante import Restaurante
from modelos.cardapio.bebida import Bebida
from modelos.cardapio.prato import Prato
from modelos.cardapio.sobremesa import SobreMesa


restaurante_praca = Restaurante('praça', 'Gourmet')

bebida_suco = Bebida('Suco de laranja', 5.0, 'grande')
bebida_suco.aplicar_desconto()
prato_italiano = Prato('Bolonhesa', 2.00, 'melhor da cidade')
prato_italiano.aplicar_desconto()
primeira_sobremesa = SobreMesa('Pudim', 30.00, 'Pudim', 'Médio', 'Pudim com creme de leite')
primeira_sobremesa.aplicar_desconto()

restaurante_praca.adicionar_no_cardapio(bebida_suco)
restaurante_praca.adicionar_no_cardapio(prato_italiano)
restaurante_praca.adicionar_no_cardapio(primeira_sobremesa)



def main():
    restaurante_praca.exibir_cardapio
    

if __name__ == '__main__':
    main()

Insira aqui a descrição dessa imagem para ajudar na acessibilidade

1 resposta
solução!

Bom dia Douglas, tudo bem com você?

É muito bom poder acompanhar de perto a sua dedicação com os estudos, continue se empenhando sempre. Para que você possa se aprofundar ainda mais nos estudos, recomendo a leitura do artigo o decorator @property em Python, que aborda com detalhes sobre o decorador @property apresentando as vantagens de sua utilização, modos de utilização e outros temas, tudo bem detalhado.

Continue estudando e conte com a Alura para evoluir sua carreira. Abraços e bons estudos!