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 Functional Python The Lambda Lambada Reduce

csr13
csr13
33,292 Points

Any guidance is appreciated.

CHALLENGE :

Finally, we're ready to find our totals. Create a variable named total. Use map() to find the per-product totals for each item in prices, then use reduce (and add) to find the total value.

My solution is attached.

prices.py
from operator import add
from functools import reduce

prices = [
    (6.99, 5),
    (2.94, 15),
    (156.99, 2),
    (99.99, 4),
    (1.82, 102)
]

def product_sales(attribute):
    return attribute[0] * attribute[1]

total = list(map(product_sales, prices))
total = reduce(add, total)

Strange, your answer seems fine. I tested it, and it returned the correct answer. Unless I didn't understand the problem, it seems fine. Craig Dennis

No problem! :-)

1 Answer

Craig Dennis
STAFF
Craig Dennis
Treehouse Teacher

Well...our test is currently being a little overly pedantic.

Try to collapse that last bit into one single line.

total = reduce(add, map(product_sales, prices))

I'll see if I can't clean that up a bit better. Your code is fine, the only thing that you don't really need is the coercion to a list. Reduce takes an iterable. So it only needs to iterate once through that way.