Path: csiph.com!x330-a1.tempe.blueboxinc.net!newsfeed.hal-mli.net!feeder3.hal-mli.net!newsfeed.hal-mli.net!feeder1.hal-mli.net!de-l.enfer-du-nord.net!feeder1.enfer-du-nord.net!feeds.phibee-telecom.net!newsfeed.xs4all.nl!newsfeed6.news.xs4all.nl!xs4all!post.news.xs4all.nl!not-for-mail Return-Path: X-Original-To: python-list@python.org Delivered-To: python-list@mail.python.org X-Spam-Status: OK 0.001 X-Spam-Evidence: '*H*': 1.00; '*S*': 0.00; 'string.': 0.04; 'python': 0.08; '>>>>': 0.09; 'beating': 0.09; 'correct.': 0.09; 'throw': 0.09; 'valueerror:': 0.09; 'subject:error': 0.09; 'exception': 0.12; 'debugging': 0.13; 'a,b,c': 0.16; 'iterable,': 0.16; 'paths.': 0.16; 'rhs': 0.16; 'roy': 0.16; 'unpack': 0.16; 'cc:addr :python-list': 0.16; 'wrote:': 0.18; 'cc:no real name:2**0': 0.20; '(most': 0.21; 'maybe': 0.21; 'header:In-Reply-To:1': 0.22; 'changed': 0.23; 'string': 0.24; 'cc:2**0': 0.24; 'traceback': 0.24; 'problem': 0.29; 'print': 0.29; 'cc:addr:python.org': 0.29; 'error': 0.29; '(the': 0.30; 'does': 0.32; 'values': 0.32; 'header :User-Agent:1': 0.33; 'too': 0.34; 'last):': 0.34; 'totally': 0.35; 'file': 0.36; 'but': 0.37; "there's": 0.37; 'spent': 0.38; 'some': 0.38; 'should': 0.39; 'why': 0.39; "it's": 0.40; 'subject:day': 0.68; 'received:62': 0.70; "'f',": 0.84; "'foo'": 0.84; 'man,': 0.91 X-IronPort-AV: E=Sophos;i="4.71,320,1320620400"; d="scan'208";a="36381" X-Virus-Scanned: amavisd-new at zimbra.sequans.com Date: Thu, 08 Dec 2011 16:03:38 +0100 From: Jean-Michel Pichavant User-Agent: Mozilla-Thunderbird 2.0.0.24 (X11/20100328) MIME-Version: 1.0 To: Roy Smith Subject: Re: Misleading error message of the day References: In-Reply-To: Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Cc: python-list@python.org X-BeenThere: python-list@python.org X-Mailman-Version: 2.1.12 Precedence: list List-Id: General discussion list for the Python programming language List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Newsgroups: comp.lang.python Message-ID: Lines: 35 NNTP-Posting-Host: 2001:888:2000:d::a6 X-Trace: 1323356627 news.xs4all.nl 6964 [2001:888:2000:d::a6]:54757 X-Complaints-To: abuse@xs4all.nl Xref: x330-a1.tempe.blueboxinc.net comp.lang.python:16833 Roy Smith wrote: > I just spent a while beating my head against this one. > > # Python 2.6 > >>>> a, b = 'foo' >>>> > Traceback (most recent call last): > File "", line 1, in > ValueError: too many values to unpack > > The real problem is that there's too *few* values to unpack! It should > have been > > a, b = 'foo', 'bar' > > I understand why it's generating the exception it does (the string is an > iterable), but man, did that message throw off my thought processes and > lead me down some totally bogus debugging paths. > > It's an unusual case to want to unpack a string. Maybe the message > should changed to "too {many, few} values to unpack (are you sure you > wanted to unpack a string?)" if the RHS is a basestring? > string are iterable, considering this, the error is correct. Values to unpack in 'foo' are 'f', 'o', 'o' > a,b,c = 'foo' > print a,b,c f o o JM