python 3中的ConfigParser与python 2相比

时间:2017-11-05 19:29:13

标签: python python-3.x configparser

我一直在慢慢地从py2过渡 - > py3和我遇到了一个我无法解决的问题(尽管我确定问题是微不足道的)。当我执行下面的代码时,配置文件似乎没有部分:(

我哪里误入歧途?

作为一个注释,我确实重用了python 2脚本中的代码(用新的configparser.ConfigParser替换旧的ConfigParser.SafeConfigParser)。我不认为这个事实是相关的,但也许是这样的?显然,我不知道:)

这是项目/ main.py

import inspect
import os
import utilities.utilities

def main():
    config_ini_path = os.path.abspath(inspect.getfile(inspect.currentframe()).split('.py')[0] + '_config.ini'
    print(config_ini_path)
    config = utilities.utilies.get_config(config_ini_path)
    print(config.sections())

if __name__ == "__main__":
    main()

这是项目/ utilities / utilities.py:

import os
import configparser
import inspect
import sys

def get_config(config_file_path=os.path.abspath(inspect.getfile(inspect.currentframe()).split('.py')[0]) + '_config.ini'):
    parser = configparser.ConfigParser()
    if os.path.exists(config_file_path):
        with open(config_file_path, 'r') as config_file:
            parser.read(config_file)
            return parser
    else:
        print('FAILED TO GET CONFIG')
        sys.exit()

def set_config(parser, config_file_path):
    if os.path.exists(config_file_path):
        with open(config_file_path, 'w') as config_file:
        parser.write(config_file)
    else:
        print('FAILED TO SET CONFIG')
        sys.exit()

最后,这是项目/ project_config.ini:

[logging]
json_config_path = /project/logging.json

有趣的是,如果我添加

config['logging'] = {'json_config_path':'project/other.json'}
utilities.utilities.set_config(config, config_ini_path)
print(config.sections())

更改将写入文件,但是,在重新执行时,它将不会被调用(由.sections()见证)。

我确定我错过了一些简单的东西!是什么赋予了?

1 个答案:

答案 0 :(得分:2)

结果.read()接受文件名,.read_file()接受文件类型。最初,我使用.readfp(),但read_file()已在py3中替换它!傻,傻我。