Path: csiph.com!usenet.pasdenom.info!aioe.org!news.stack.nl!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.000 X-Spam-Evidence: '*H*': 1.00; '*S*': 0.00; 'algorithm': 0.03; 'linear': 0.07; 'subject:file': 0.07; 'url:pycon': 0.07; 'brackets': 0.09; 'dict': 0.09; 'iterate': 0.09; 'received:mail- lpp01m010-f46.google.com': 0.09; 'to:addr:python.list': 0.09; 'to:addr:tim.thechases.com': 0.09; 'to:name:tim chase': 0.09; 'tuple': 0.09; 'cc:addr:python-list': 0.10; "wouldn't": 0.11; '(2,': 0.16; "(i'm": 0.16; '-tkc': 0.16; '3):': 0.16; 'cleanly': 0.16; 'entries,': 0.16; 'generator.': 0.16; 'iterating': 0.16; 'readable': 0.16; 'semicolon': 0.16; 'wrote:': 0.17; 'version.': 0.17; 'tim': 0.18; '>>>': 0.18; 'appropriate': 0.20; 'x-mailer:apple mail (2.1084)': 0.22; "python's": 0.23; 'cc:2**1': 0.24; 'cc:addr:python.org': 0.25; 'header:In-Reply-To:1': 0.25; 'cc:addr:gmail.com': 0.27; 'entries': 0.27; "doesn't": 0.28; 'this?': 0.28; '>>>>': 0.29; 'chase': 0.29; 'overhead': 0.29; 'received:209.85.215.46': 0.30; 'point': 0.31; 'url:python': 0.32; 'file': 0.32; 'print': 0.32; "can't": 0.34; 'received:google.com': 0.34; 'list': 0.35; 'faster': 0.35; 'received:209.85': 0.35; 'something': 0.35; 'message-id:@gmail.com': 0.36; 'cc:no real name:2**1': 0.36; 'uses': 0.37; 'why': 0.37; 'item': 0.37; 'received:209': 0.37; 'subject:: ': 0.38; 'header:Received:5': 0.40; 'think': 0.40; 'link': 0.60; 'header:Message-Id:1': 0.62; 'more': 0.63; 'making': 0.64; 'touch': 0.69; 'received:ru': 0.81; 'actually,': 0.84; 'difference.': 0.84; 'different.': 0.84; 'url:2007': 0.84; 'hundred': 0.95 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=subject:mime-version:content-type:from:in-reply-to:date:cc :content-transfer-encoding:message-id:references:to:x-mailer; bh=jBX8j56Gr/3mTfu2h8t1AraJAAr0WTRjo3fEBPK02XI=; b=juoo0J3LInTgc+mE0WgQJQI2mLv4l0nNRPSdJqyCJorH0CfyijLYY+1ikQeqjKWP5w 5w9hffwSPbTPzJegmAHYQAhZn2t0mJDthh7wCUQaoXOeJ3SN+xAc59Z2XjiWtJiXj7SY Yh3rDk8DtcTDJGAtdhuzLcQdJ/Pios/cmS5ry1yeNKDeFCyK5z3QeeUIwglG2ldkDa4Q m1Iq/GfBfSJ/jnbWLgAKLs0UBJqSBtJNRrlhfuoL4C/UMgZ8ji+4yeCF7lWcBNU5j6F6 duVVmxMg/sWXfctDp9E6AwMU2A+Pldb6Ri5m0N8iShdLL3v+95Yv6r8WBdWJexLgcESq 9sBA== Subject: Re: save dictionary to a file without brackets. Mime-Version: 1.0 (Apple Message framework v1084) Content-Type: text/plain; charset=koi8-r From: Roman Vashkevich In-Reply-To: <502429C3.5000600@tim.thechases.com> Date: Fri, 10 Aug 2012 01:34:05 +0400 Content-Transfer-Encoding: quoted-printable References: <930ab3d8-4ab9-446d-9970-ee811eb70a44@googlegroups.com> <50241F14.2060209@tim.thechases.com> <36EA3847-6713-4C12-B47B-9B5E10325F00@gmail.com> <502429C3.5000600@tim.thechases.com> To: Tim Chase X-Mailer: Apple Mail (2.1084) Cc: python-list@python.org, giuseppe.amatulli@gmail.com 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: 52 NNTP-Posting-Host: 2001:888:2000:d::a6 X-Trace: 1344548050 news.xs4all.nl 6866 [2001:888:2000:d::a6]:38264 X-Complaints-To: abuse@xs4all.nl Xref: csiph.com comp.lang.python:26817 Actually, they are different. Put a dict.{iter}items() in an O(k^N) algorithm and make it a hundred = thousand entries, and you will feel the difference. Dict uses hashing to get a value from the dict and this is why it's = O(1). 10.08.2012, =D7 1:21, Tim Chase =CE=C1=D0=C9=D3=C1=CC(=C1): > On 08/09/12 15:41, Roman Vashkevich wrote: >> 10.08.2012, =D7 0:35, Tim Chase =CE=C1=D0=C9=D3=C1=CC(=C1): >>> On 08/09/12 15:22, Roman Vashkevich wrote: >>>>> {(4, 5): 1, (5, 4): 1, (4, 4): 2, (2, 3): 1, (4, 3): 2} >>>>> and i want to print to a file without the brackets comas and = semicolon in order to obtain something like this? >>>>> 4 5 1 >>>>> 5 4 1 >>>>> 4 4 2 >>>>> 2 3 1 >>>>> 4 3 2 >>>>=20 >>>> for key in dict: >>>> print key[0], key[1], dict[key] >>>=20 >>> This might read more cleanly with tuple unpacking: >>>=20 >>> for (edge1, edge2), cost in d.iteritems(): # or .items() >>> print edge1, edge2, cost >>>=20 >>> (I'm making the assumption that this is a edge/cost graph...use >>> appropriate names according to what they actually mean) >>=20 >> dict.items() is a list - linear access time whereas with 'for >> key in dict:' access time is constant: >> = http://python.net/~goodger/projects/pycon/2007/idiomatic/handout.html#use-= in-where-possible-1 >=20 > That link doesn't actually discuss dict.{iter}items() >=20 > Both are O(N) because you have to touch each item in the dict--you > can't iterate over N entries in less than O(N) time. For small > data-sets, building the list and then iterating over it may be > faster faster; for larger data-sets, the cost of building the list > overshadows the (minor) overhead of a generator. Either way, the > iterate-and-fetch-the-associated-value of .items() & .iteritems() > can (should?) be optimized in Python's internals to the point I > wouldn't think twice about using the more readable version. >=20 > -tkc >=20 >=20