Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Python ConfigParser: Checking for option existence

I'm using Python's ConfigParser to create a configuration file. I want to check if a section has a particular option defined and, if it does, get the value. If the option isn't defined, I just want to continue without any special behavior. There seem to be two ways of doing this.

if config.has_option('Options', 'myoption'):
    OPTION = config.get('Options', 'myoption')

Or:

try:
    OPTION = config.get('Options', 'myoption')
except ConfigParser.NoOptionError:
    pass

Is one method preferred over the other? The if involves less lines, but I've occasionally read that try/except is considered more pythonic in many cases.

like image 870
user1272534 Avatar asked Jul 17 '12 17:07

user1272534


People also ask

How do I use Configparser in Python?

Read and parse one configuration file, given as a file object. Read configuration from a given string. Read configuration from a dictionary. Keys are section names, values are dictionaries with keys and values that should be present in the section.

Does Configparser come with Python?

configparser comes from Python 3 and as such it works well with Unicode.


1 Answers

The choice between try/except and if-condition is a fuzzy line.

  1. If you expect the exception to be quite rare, use try/except as it more closely models thinking
  2. Conversely, "expected" exceptions like a configuration item missing, are part of the normal flow of control and the code should reflect that.

There is no clearly superior choice, but it sounds like you've got a case of (2) so I'd opt for if/then. This completely ignores aspects of Easier to ask Forgiveness Than Permission and the relative efficiencies of the structures.

like image 173
msw Avatar answered Sep 27 '22 19:09

msw