我使用 ConfigParser 从配置文件加载数据,如下所示:
测试.conf:
[myfiles]
fileone: %(datadir)s/somefile.foo
filetwo: %(datadir)s/nudderfile.foo
load.py:
import ConfigParser
config = ConfigParser.ConfigParser({'datadir': '/tmp'})
config.read('test.conf')
print config.items('myfiles')
print config.get('myfiles', 'datadir')
Output:
$ python load.py
[('datadir', '/tmp'), ('filetwo', '/tmp/nudderfile.foo'), ('fileone', '/tmp/somefile.foo')]
/tmp
我很惊讶变量替换的默认值('datadir', '/tmp')
正在作为 的一部分出现。items()
and .get()
返回,就像它们是配置文件中的值一样。这种行为是预期的吗?任何解决方法,以便我可以简单地迭代.items()
没有获取默认字典值,但仍然使用魔术插值?
参考:http://docs.python.org/library/configparser.html http://docs.python.org/library/configparser.html
Thanks!
Update:有人指出,这是预期的行为:默认值就像配置文件中的任何其他名称/值对一样。同样,配置文件中的名称/值对也可用于“神奇插值”,因此如果我定义:
foo: bar
zap: %(foo)snowl
我去拿[... ('zap': 'barnowl')]
这非常简洁,但我仍然想知道是否可以完成我想要完成的任务:迭代配置文件中的名称/值对,使用变量插值,而不使用默认值。
我的具体场景是这样的:我想用类似的东西初始化配置对象{basedir: '/foo/bar'}
,因为某些文件的绝对路径因安装而异。然后我需要将该配置对象传递给并让各种其他类迭代这些文件。我不希望每个读取配置的类都必须知道它是使用某些默认值初始化的,并且应该忽略它们,因为它们不是实际的文件。这可能吗?有什么办法可以隐藏 .item() 和 .get() 的默认值但仍然有插值?谢谢!