Esto ya está hecho para usted en config._sections
. Ejemplo:
$ cat test.ini
[First Section]
var = value
key = item
[Second Section]
othervar = othervalue
otherkey = otheritem
Y luego:
>>> from ConfigParser import ConfigParser
>>> config = ConfigParser()
>>> config.read('test.ini')
>>> config._sections
{'First Section': {'var': 'value', '__name__': 'First Section', 'key': 'item'}, 'Second Section': {'__name__': 'Second Section', 'otherkey': 'otheritem', 'othervar': 'othervalue'}}
>>> config._sections['First Section']
{'var': 'value', '__name__': 'First Section', 'key': 'item'}
Editar: Mi solución al mismo problema se downvoted así que voy a ilustrar con más detalle la forma en que mi respuesta hace lo mismo sin tener que pasar a la sección a través de dict()
, porque config._sections
es proporcionado por el módulo para usted ya.
Ejemplo Prueba.ini:
[db]
dbname = testdb
dbuser = test_user
host = localhost
password = abc123
port = 3306
suceso Magic:
>>> config.read('test.ini')
['test.ini']
>>> config._sections
{'db': {'dbname': 'testdb', 'host': 'localhost', 'dbuser': 'test_user', '__name__': 'db', 'password': 'abc123', 'port': '3306'}}
>>> connection_string = "dbname='%(dbname)s' user='%(dbuser)s' host='%(host)s' password='%(password)s' port='%(port)s'"
>>> connection_string % config._sections['db']
"dbname='testdb' user='test_user' host='localhost' password='abc123' port='3306'"
Así que esta solución es no mal, y que en realidad requiere un paso menos. ¡Gracias por pasar!
Tenga cuidado al usar _sections: esta variable no está documentada, por lo que no se garantiza que funcione en versiones futuras de python – Bertera
Esto es válido para python 2, pero si está utilizando python 3 puede simplemente descomprimir la configuración subscripta en formato(). "su {patrón}". Formato (** config ['db']) – Hovis