Argparse - configparser.Interpolation缺少选项错误

时间:2015-10-12 12:39:33

标签: python configparser

我正在使用Argparse从配置文件中获取必要的值。

例如:

python arg.py --event_conf=/opt/open-stack-tools/track_events.conf --openstack_conf=/etc/nova/nova.conf

我需要从两个不同的文件中获取值。

我可以根据需要获得一个本地配置文件的结果。

但是如果从nova.conf文件中获取必要的值,则会导致以下错误:

       Traceback (most recent call last):
          File "arg.py", line 36, in <module>
            oslo_messaging_rabbit= dict(config.items("oslo_messaging_rabbit"))
          File "/usr/lib/python2.7/ConfigParser.py", line 655, in items
            for option in options]
          File "/usr/lib/python2.7/ConfigParser.py", line 691, in _interpolate
            self._interpolate_some(option, L, rawval, section, vars, 1)
          File "/usr/lib/python2.7/ConfigParser.py", line 723, in _interpolate_some
            option, section, rest, var)
ConfigParser.InterpolationMissingOptionError: Bad value substitution:
        section: [oslo_messaging_rabbit]
        option : logging_exception_prefix
        key    : color
        rawval : %(asctime)s.%(msecs)03d TRACE %(name)s %(instance)s

有没有办法解决这个问题。

我已经复制了必要的内容并创建了一个新的本地文件,我可以看到它工作正常。

当我使用nova.conf文件时,会导致错误。

我无法更改我正在使用的文件。

所以我需要修复特定的错误。

注意:

根据需要添加更多详细信息:

parser.add_argument("-c", "--event_conf",
                    help="Specify config file 1", metavar="FILE")
args1, remaining_argv1 = parser.parse_known_args()


parser.add_argument("-o", "--openstack_conf",
                    help="Specify config file 2", metavar="FILE")
args2, remaining_argv2 = parser.parse_known_args()


if args1.event_conf:
    config = ConfigParser.SafeConfigParser()
    print config.read([args1.event_conf])
    config.read([args1.event_conf])
    configdetails_section1 = dict(config.items("configdetails_section1"))

2 个答案:

答案 0 :(得分:4)

我找到了相同的解决方案。

实际上问题出在我使用过的configparser上。

而不是 SafeConfigParser 我将其更改为 RawConfigParser

然后我可以看到它工作正常。

答案 1 :(得分:1)

插值允许您在定义其他值时引用配置的值。例如,在此配置文件中:

[bug_tracker]
protocol = http
server = localhost
port = 8080
url = %(protocol)s://%(server)s:%(port)s/bugs/
username = dhellmann
password = SECRET

如果你这样读:

from ConfigParser import SafeConfigParser

parser = SafeConfigParser()
parser.read('interpolation.ini')

print 'value =', parser.get('bug_tracker', 'url')

你会得到:

value = http://localhost:8080/bugs/

这可能非常有用,问题似乎是你在运行时传递了一些值。我的意思是你需要格式字符串来实际替换这些值。

您可以使用RawConfigParser代替SafeConfigParser,但随后会松开所有插值。

相反,您可以抑制一个特定值的插值:

print 'value =', parser.get('bug_tracker', 'url', raw=True)

,结果将是:

value = %(protocol)s://%(server)s:%(port)s/bugs/

您还可能需要将插值与其中一些在评估时间中给出的值组合在一起。例如,如果您想在评估时间内提供user,您还可以将其包含在配置表达式中:

[bug_tracker]
protocol = http
server = localhost
port = 8080
url = %(protocol)s://%(user)s@%(server)s:%(port)s/bugs/
username = dhellmann
password = SECRET

然后你需要做这样的事情:

from ConfigParser import SafeConfigParser

parser = SafeConfigParser()
parser.read('interpolation.ini')

parser.set('bug_tracker', 'user', 'admin')
print 'value =', parser.get('bug_tracker', 'url')

你会得到:

value = http://admin@localhost:8080/bugs/

很抱歉,我没有使用你的例子。我确实拿了另一个项目的文档中的一个。请参阅以下部分:Combining Values with Interpolation