Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > comp.lang.python > #89622
| Path | csiph.com!v102.xanadu-bbs.net!xanadu-bbs.net!feeder.erje.net!1.eu.feeder.erje.net!feeds.phibee-telecom.net!news.panservice.it!feed.xsnews.nl!border02.ams.xsnews.nl!feeder04.ams.xsnews.nl!feeder03.ams.xsnews.nl!abp001.ams.xsnews.nl!frontend-F10-06.ams.news.kpn.nl |
|---|---|
| From | Cecil Westerhof <Cecil@decebal.nl> |
| Newsgroups | comp.lang.python |
| Subject | Re: Let exception fire or return None |
| Organization | Decebal Computing |
| References | <87bni6awol.fsf@Equus.decebal.nl> <mailman.122.1430386245.3680.python-list@python.org> |
| X-Face | "(y8cC@tg_12{">GF'UXTW]FHI2wMiZNrnf'1EFQ&O#$m:f#O7+7}kR<J%a^F2lh4[N~Yz4 nSp#c+aQo1b5=?HcNEkQ7QzF<])O3X4MDL/AYjys&*mt>,v+Pti8=Vi/Z"g^?b"E |
| X-Homepage | http://www.decebal.nl/ |
| Date | Thu, 30 Apr 2015 13:26:01 +0200 |
| Message-ID | <87h9rxx3g6.fsf@Equus.decebal.nl> (permalink) |
| User-Agent | Gnus/5.13 (Gnus v5.13) Emacs/24.3 (gnu/linux) |
| Cancel-Lock | sha1:xcQ2whpXoKorjBudAC3m8qnRR0s= |
| MIME-Version | 1.0 |
| Content-Type | text/plain; charset=utf-8 |
| Content-Transfer-Encoding | 8bit |
| Lines | 59 |
| NNTP-Posting-Host | 81.207.62.244 |
| X-Trace | 1430393333 news.kpn.nl 21095 81.207.62.244@kpn/81.207.62.244:37546 |
| Xref | csiph.com comp.lang.python:89622 |
Show key headers only | View raw
Op Thursday 30 Apr 2015 11:30 CEST schreef Peter Otten: > Cecil Westerhof wrote: > >> I have a function to fetch a message from a file: >> def get_indexed_message(message_filename, index): >> """ >> Get index message from a file, where 0 gets the first message >> """ >> >> return open(expanduser(message_filename), >> 'r').readlines()[index].rstrip() >> >> What is more the Python way: let the exception fire like this code >> when index is to big, or catching it and returning None? > > Fire an exception, but you may also allow the user to provide a > default. > >> I suppose working zero based is OK. > > Not just OK, it's de rigueur. > > > You didn't ask for that, but > > (1) > > with open(...) as f: > return f.readlines()[index].rstrip() > > is preferrable because it closes the file in a controlled way and I already did that. In another thread I got to know my assumptions where wrong. > (2) you may want to take measures to limit memory usage, e. g. > > assert index >= 0 I put that in, but as first statement. > try: > [line] = itertools.islice(f, index, index+1) > except ValueError: > raise IndexError > return line.rstrip() In my case it is not important. (The biggest file I use has between 100 and 200 lines), but I publish it, so I should do my best to make it so lean as possible. To quote a famous comedian: ‘Learning all the time’. -- Cecil Westerhof Senior Software Engineer LinkedIn: http://www.linkedin.com/in/cecilwesterhof
Back to comp.lang.python | Previous | Next — Previous in thread | Next in thread | Find similar | Unroll thread
Let exception fire or return None Cecil Westerhof <Cecil@decebal.nl> - 2015-04-30 09:43 +0200
Re: Let exception fire or return None Dave Angel <davea@davea.name> - 2015-04-30 04:18 -0400
Re: Let exception fire or return None Cecil Westerhof <Cecil@decebal.nl> - 2015-04-30 11:13 +0200
Re: Let exception fire or return None Peter Otten <__peter__@web.de> - 2015-04-30 11:30 +0200
Re: Let exception fire or return None Cecil Westerhof <Cecil@decebal.nl> - 2015-04-30 13:26 +0200
Re: Let exception fire or return None Peter Otten <__peter__@web.de> - 2015-04-30 14:28 +0200
Re: Let exception fire or return None Cecil Westerhof <Cecil@decebal.nl> - 2015-04-30 16:53 +0200
Re: Let exception fire or return None Cecil Westerhof <Cecil@decebal.nl> - 2015-04-30 14:22 +0200
Re: Let exception fire or return None Thomas 'PointedEars' Lahn <PointedEars@web.de> - 2015-04-30 14:05 +0200
Re: Let exception fire or return None Antoon Pardon <antoon.pardon@rece.vub.ac.be> - 2015-04-30 14:30 +0200
csiph-web