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

terence
13,407 PointsAdd a __eq__ method for this book class. It should check if the author and title of the book are the same and return tru
class Book: def init(self, author, title): self.author = author self.title = title
def __str__(self):
return f"{self.author}, {self.title}"
class Book:
def __init__(self, author, title):
self.author = author
self.title = title
def __str__(self):
return f"{self.author}, {self.title}"
from book import Book
class BookCase:
def __init__(self):
self.books = []
def add_books(self, book):
self.books.append(book)
2 Answers

terence
13,407 Pointsthis part of the code is an error some how def eq(self, other): if isinstance(other, Book): return self.author == other.author and self.title == other.title return False

Travis Alstrand
Treehouse Project ReviewerHey there terencelewis !
You're super close here! It just needs a little adjustment. The challenge reads "It should check if the author and title of the book are the same and return true if they are and false if they aren’t." So I believe the isinstance
check you had in place is what was throwing the answer validation on the back end off.
class Book:
def __init__(self, author, title):
self.author = author
self.title = title
def __str__(self):
return f"{self.author}, {self.title}"
def __eq__(self, other):
if self.author == other.author and self.title == other.title:
return True
else:
return False