Welcome to the Treehouse Community

Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.

Looking to learn something new?

Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.

Start your free trial

Python Using Databases in Python Meet Peewee Create Table

chris clarkson
chris clarkson
1,380 Points

Creating tables task 3 of 4: "bject has no attribute 'name'

from peewee import * db=SqliteDatabase("challenges.db") def Challenge(Model): name = CharField(max_length=100, unique=True) language=CharField(max_length=100, unique=True)

Yields the following error:

Bummer! bject has no attribute 'name'

tables.py
from peewee import *
db=SqliteDatabase("challenges.db")
def Challenge(Model):
    name = CharField(max_length=100, unique=True)
    language=CharField(max_length=100, unique=True)

1 Answer

Jacob Herrington
Jacob Herrington
15,835 Points

You are really close!

Instead of making a function with "def", you should be using "class". You also don't need the "unique=True" argument.

from peewee import *
db=SqliteDatabase("challenges.db")
class Challenge(Model):
    name = CharField(max_length=100)
    language = CharField(max_length=100)
chris clarkson
chris clarkson
1,380 Points

oh god that's embarrassing thanks

Jacob Herrington
Jacob Herrington
15,835 Points

Absolutely not embarrassing -- this kind of stuff happens to every programmer, especially when you're learning something new!