-
Notifications
You must be signed in to change notification settings - Fork 0
/
desafio_v1.py
174 lines (127 loc) · 4.41 KB
/
desafio_v1.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
from abc import ABC, abstractclassmethod, abstractproperty
from datetime import datetime
class Cliente:
def __init__(self, endereco):
self.endereco = endereco
self.contas = []
def realizar_transacao(self, conta, transacao):
transacao.registrar(conta)
def adicionar_conta(self, conta):
self.contas.append(conta)
class PessoaFisica(Cliente):
def __init__(self, nome, data_nascimento, cpf, endereco):
super().__init__(endereco)
self.nome = nome
self.data_nascimento = data_nascimento
self.cpf = cpf
class Conta:
def __init__(self, numero, cliente):
self._saldo = 0
self._numero = numero
self._agencia = "0001"
self._cliente = cliente
self._historico = Historico()
@classmethod
def nova_conta(cls, cliente, numero):
return cls(numero, cliente)
@property
def saldo(self):
return self._saldo
@property
def numero(self):
return self._numero
@property
def agencia(self):
return self._agencia
@property
def cliente(self):
return self._cliente
@property
def historico(self):
return self._historico
def sacar(self, valor):
saldo = self.saldo
excedeu_saldo = valor > saldo
if excedeu_saldo:
print("\n@@@ Operação falhou! Você não tem saldo suficiente. @@@")
elif valor > 0:
self._saldo -= valor
print("\n=== Saque realizado com sucesso! ===")
return True
else:
print("@@@ Operação falhou! Valor informado é inválido. @@@")
return False
def depositar(self, valor):
if valor > 0:
self._saldo += valor
print("\n=== Depósito realizado com sucesso! ===")
else:
print("\n@@@ Operação falhou! O valor informado é inválido. @@@")
return False
return True
class ContaCorrente(Conta):
def __init__(self, numero, cliente, limite=500, limite_saques=3):
super().__init__(numero, cliente)
self.limite = limite
self.limite_saques = limite_saques
def sacar(self, valor):
numero_saques = len(
[transacao for transacao in self._historico.transacoes if transacao["tipo"] == Saque.__name__]
)
excedeu_limite = valor > self.limite
excedeu_saques = numero_saques >= self.limite_saques
if excedeu_limite:
print("\n@@@ Operação falhou! O valor do saque exece o limite. @@@")
elif excedeu_saques:
print("@@@ Operação falhou! Número máximo de saques excedido. @@@")
else:
return super().sacar(valor)
return False
def __str__(self):
return f"""\
Agência:\t{self.agencia}
C/C:\t\t{self.numero}
Titular:\t{self.cliente.nome}
"""
class Historico:
def __init__(self):
self.transacoes = []
@property
def transacoes(self):
return self._transacoes
def adicionar_transacao(self, transacao):
self._transacoes.append(
{
"tipo": transacao.__class__.__name__,
"valor": transacao.valor,
"data": datetime.now().strftime("%d-%m-%Y %H:%M:%s"),
}
)
class Transacao(ABC):
@property
@abstractproperty
def valor(self):
pass
@abstractclassmethod
def registrar(self, conta):
pass
class Saque(Transacao):
def __init__(self, valor):
self.valor = valor
@property
def valor(self):
return self._valor
def registrar(self, conta):
sucesso_transacao = conta.sacar(self.valor)
if sucesso_transacao:
conta.historico.adcionar_transacao(self)
class Deposito(Transacao):
def __init__(self, valor):
self.valor = valor
@property
def valor(self):
return self.valor
def registrar(self, conta):
sucesso_transacao = conta.depositar(self.valor)
if sucesso_transacao:
conta.historico.adicionar_transacao(self)