Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > comp.lang.python > #89633
| 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> <87h9rxx3g6.fsf@Equus.decebal.nl> <mailman.127.1430396946.3680.python-list@python.org> |
| Date | 2015-04-30 16:53 +0200 |
| Message-ID | <87sibhvf9k.fsf@Equus.decebal.nl> (permalink) |
Op Thursday 30 Apr 2015 14:28 CEST schreef Peter Otten: > Cecil Westerhof wrote: > >>> (2) you may want to take measures to limit memory usage, e. g. >>> >>> assert index >= 0 >> >> I put that in, but as first statement. > > For the record, this was not a recommended check, but rather a way > to communicate to the reader of my code that unlike yours it doesn't > support negative indices. > >>> 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. > > If you keep your > > return f.readlines()[index] > > anyway you might allow for negative indices, and then > > get_indexed_message(message_filename, -1) > > fetches the last message in the file and > > get_indexed_message(message_filename, slice(None, None)) > > fetches a list with all messages. It is even possible without keeping it. I can fetch the number of messages and implement it myself without a possible high memory overhead. Certainly something to think about. -- 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