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 Object-Oriented Python Instant Objects Method Interactivity

Challenge: Does the "grade" argument need a defined value? Where do I need to use "self" in feedback method?

Instructions: "Alright, I need you make a new method named feedback. It should take an argument named grade. Methods take arguments just like functions do. You'll still need self in there, though.

If grade is above 50, return the result of the praise method. If it's 50 or below, return the reassurance method's result."

first_class.py
class Student:
    name = "Your Name"

    def praise(self):
        return "You inspire me, {}".format(self.name)

    def reassurance(self):
        return "Chin up, {}. You'll get it next time!".format(self.name)

    def feedback(self, grade) 
        if grade > 50:
            return praise(self)
        else grade <== 50
            return reassurance(self)

You might want to try your code in a workspace and add:

s = Student()
print(s.feedback(50))

You'll get better feedback than "Bummer Try Again"

1 Answer

Steven Parker
Steven Parker
228,978 Points

I'm not sure what you mean by "defined value" regarding "grade" (it's a parameter, so the answer is probably "no").

But the way you use "self" is as the basis for calling the internal methods, for example:

            return self.praise()    # instead of "praise(self)"

And a few more hints:

  • the "def" line should end with a colon
  • "<==" is not a python operator
  • a plain "else" does not use a conditional expression
  • the "else" should also end with a colon

Thank you Steven Parker! I was able to complete the challenge with your tips. However, I don't understand self here and its position in the function. How should I read self.praise() vs praise(self)? Can you explain a bit more why one works the other doesn't?

Separate question, is there a more readable way to write this function other than this?

def feedback(self, grade) 
        if grade > 50:
            return self.praise()
        else:
            return self.reassurance()

Thanks again!

Steven Parker
Steven Parker
228,978 Points

I think you nailed it. Good job!