em self.name o name nao foi atribuido ele nao existe, você criou um varialvel que se chama nome, talvez queria chamar ela no self
Eu fiz a mudança mas continuou aparencendo o mesmo erro
from flask import Flask, render_template, request, redirect, session, flash, url_for
from flask_sqlalchemy import SQLAlchemy
class Jogo:
def __init__(self, name, categoria, console):
self.name = name
self.categoria = categoria
self.console = console
jogo1 = Jogo('Tetris', 'Puzzle', 'Atari')
jogo2 = Jogo('God of War', 'Rack in Slash', 'PS2')
jogo3 = Jogo('Mortal Kombat', 'Luta', 'PS2')
lista = [jogo1, jogo2, jogo3]
class Usuario:
def __init__(self, name, nickname, senha):
self.name = name
self.nickname = nickname
self.senha = senha
usuario1 = Usuario('Bruno Divino', 'BD', 'alohomora')
usuario2 = Usuario('Camila Ferreira', 'Mila', 'paozinho')
usuario3 = Usuario('Guilherme Louro', 'Cake', 'python_eh_vida')
usuarios = {usuario1.nickname:usuario1,
usuario2.nickname:usuario2,
usuario3.nickname:usuario3}
app = Flask(__name__)
app.secret_key = 'alura'
app.config['SQLALCHEMY_DATABASE_URI'] = \
'{SGBD}://{usuario}:{senha}@{servidor}/{database}'.format(
SGBD = 'mysql+mysqlconnector',
usuario = 'root',
senha = 'livro',
servidor = 'localhost',
database = 'jogoteca'
)
db = SQLAlchemy(app)
class Jogos(db.Model):
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
nome = db.Column(db.String(50), nullable=False)
categoria = db.Column(db.String(40), nullable=False)
console = db.Column(db.String(20), nullable=False)
def __repr__(self):
return '<Name %r>' % self.name
class Usuarios(db.Model):
nickname = db.Column(db.String(8), primary_key=True)
nome = db.Column(db.String(20), nullable=False)
senha = db.Column(db.String(100), nullable=False)
def __repr__(self):
return '<Name %r>' % self.name
@app.route('/')
def index():
return render_template('lista.html', titulo='Jogos', jogos=lista)
@app.route('/novo')
def novo():
if 'usuario_logado' not in session or session['usuario_logado'] == None:
return redirect(url_for('login', proxima=url_for('novo')))
return render_template('novo.html', titulo='Novo Jogo')
@app.route('/criar', methods=['POST',])
def criar():
# Formulario
nome = request.form['nome']
categoria = request.form['categoria']
console = request.form['console']
jogo = Jogo(nome, categoria, console)
lista.append(jogo)
return redirect(url_for('index'))
@app.route('/login')
def login():
proxima = request.args.get('proxima')
return render_template('login.html', proxima=proxima)
@app.route('/autenticar', methods=['POST',])
def autenticar():
if request.form['usuario'] in usuarios:
usuario = usuarios[request.form['usuario']]
if request.form['senha'] == usuario.senha:
session['usuario_logado'] = usuario.nickname
flash(usuario.nickname + ' logado com sucesso!')
proxima_pagina = request.form['proxima']
return redirect(proxima_pagina)
else:
flash('Usuario não logado!')
return redirect(url_for('login'))
@app.route('/logout')
def logout():
session['usuario_logado'] = None
flash('Logout efetuado com sucesso!')
return redirect(url_for('index'))
app.run(debug=True)
No método repr das classes Jogos e Usuarios, você está tentando acessar um atributo que não existe (self.name). Em vez disso, deve ser self.nome para a classe Jogos e self.nickname para a classe Usuar
Certifique-se de que você tem todas as dependências instaladas (Flask, Flask-SQLAlchemy.).