Path: csiph.com!fu-berlin.de!uni-berlin.de!not-for-mail From: Mark Lawrence Newsgroups: comp.lang.python Subject: Re: Simple exercise Date: Fri, 11 Mar 2016 01:21:21 +0000 Lines: 77 Message-ID: References: Mime-Version: 1.0 Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit X-Trace: news.uni-berlin.de edv8qd6iPncqSmOwVRJ7sQbMpC/l1IxINNhjhsFIA8yA== Return-Path: X-Original-To: python-list@python.org Delivered-To: python-list@mail.python.org X-Spam-Status: OK 0.000 X-Spam-Evidence: '*H*': 1.00; '*S*': 0.00; 'skip:[ 20': 0.03; 'from:addr:yahoo.co.uk': 0.05; 'data:': 0.07; 'except:': 0.07; 'input,': 0.09; 'received:80.91': 0.09; 'received:80.91.229': 0.09; 'received:gmane.org': 0.09; 'received:list': 0.09; 'output': 0.13; 'def': 0.13; 'appropriate': 0.14; '5",': 0.16; 'combined.': 0.16; 'key/value': 0.16; 'received:80.91.229.3': 0.16; 'received:io': 0.16; 'received:plane.gmane.org': 0.16; 'received:psf.io': 0.16; 'still,': 0.16; 'wrote:': 0.16; 'element': 0.18; 'try:': 0.18; 'version.': 0.18; 'input': 0.18; 'language': 0.19; '>>>': 0.20; 'lawrence': 0.22; 'sets': 0.23; 'header:In-Reply-To:1': 0.24; 'header:User-Agent:1': 0.26; 'header:X-Complaints-To:1': 0.26; 'skip:( 20': 0.28; "i'm": 0.30; 'print': 0.30; 'code': 0.30; 'entry': 0.31; 'language.': 0.32; 'subject:Simple': 0.33; 'file': 0.34; 'except': 0.34; 'gives': 0.35; 'lists.': 0.35; 'expected': 0.35; 'but': 0.36; 'serve': 0.36; 'apple': 0.36; 'to:addr:python-list': 0.36; 'subject:: ': 0.37; 'two': 0.37; 'received:org': 0.37; 'names': 0.38; 'wrong': 0.38; 'data': 0.39; 'easily': 0.39; 'rather': 0.39; 'to:addr:python.org': 0.40; 'mark': 0.40; 'collection': 0.60; 'charset:windows-1252': 0.62; 'skip:n 10': 0.62; 'our': 0.64; 'results.': 0.67; 'pythonistas,': 0.84 X-Injected-Via-Gmane: http://gmane.org/ X-Gmane-NNTP-Posting-Host: 80.234.129.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:38.0) Gecko/20100101 Thunderbird/38.6.0 In-Reply-To: X-BeenThere: python-list@python.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: General discussion list for the Python programming language List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Xref: csiph.com comp.lang.python:104570 On 11/03/2016 00:05, BartC wrote: > On 10/03/2016 09:02, Rodrick Brown wrote: >>> From the following input >> >> 9 >> BANANA FRIES 12 >> POTATO CHIPS 30 >> APPLE JUICE 10 >> CANDY 5 >> APPLE JUICE 10 >> CANDY 5 >> CANDY 5 >> CANDY 5 >> POTATO CHIPS 30 >> >> I'm expecting the following output >> BANANA FRIES 12 >> POTATO CHIPS 60 >> APPLE JUICE 20 >> CANDY 20 > > > Here's a rather un-Pythonic and clunky version. But it gives the > expected results. (I've dispensed with file input, but that can easily > be added back.) > > def last(a): > return a[-1] > > def init(a): # all except last element > return a[0:len(a)-1] What is wrong with a[0:1] ? > > data =["BANANA FRIES 12", # 1+ items/line, last must be numeric > "POTATO CHIPS 30", > "APPLE JUICE 10", > "CANDY 5", > "APPLE JUICE 10", > "CANDY 5", > "CANDY 5", > "CANDY 5", > "POTATO CHIPS 30"] > > names = [] # serve as key/value sets > totals = [] > > for line in data: # banana fries 12 > parts = line.split(" ") # ['banana','fries','12'] > value = int(last(parts)) # 12 > name = " ".join(init(parts)) # 'banana fries' > > try: > n = names.index(name) # update existing entry > totals[n] += value > except: Never use a bare except. Better still, use an appropriate collection rather than two lists. Off of the top of my head a counter or a defaultdict. > names.append(name) # new entry > totals.append(value) > > for i in range(len(names)): > print (names[i],totals[i]) > Always a code smell when range() and len() are combined. -- My fellow Pythonistas, ask not what our language can do for you, ask what you can do for our language. Mark Lawrence