Welcome to the Treehouse Community

The Treehouse Community is a meeting place for developers, designers, and programmers of all backgrounds and skill levels to get support. Collaborate here on code errors or bugs that you need feedback on, or asking for an extra set of eyes on your latest project. Join thousands of Treehouse students and alumni in the community today. (Note: Only Treehouse students can comment or ask questions, but non-students are welcome to browse our conversations.)

Looking to learn something new?

Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and a supportive community. Start your free trial today.

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."

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()

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

1 Answer

Steven Parker
Steven Parker
215,939 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()
            return self.reassurance()

Thanks again!

Steven Parker
Steven Parker
215,939 Points

I think you nailed it. Good job!