Python 标准模块 ConfigParser(转)

本文介绍使用Python的ConfigParser模块来读取和修改配置文件的方法。涵盖了如何读取配置文件的基本信息,包括获取不同类型的值(如字符串、整数等),以及如何添加新的配置项并保存到文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

20160520update: 最省事的还是读JSON

#=====================================

发现python读写配置文件比较方便。

import ConfigParser

接口:ConfigParser.ConfigParser()

读写文件:read write


结构: config file =>sections=>options=>items


读取某个option的值(str): get(section,option)



1) 基本的读取配置文件
     -read(filename) 直接读取ini文件内容
     -sections() 得到所有的section,并以列表的形式返回
     -options(section) 得到该section的所有option
     -items(section) 得到该section的所有键值对
     -get(section,option) 得到section中option的值,返回为string类型
     -getint(section,option) 得到section中option的值,返回为int类型,还有相应的getboolean()和getfloat() 函数。

2.基本的写入配置文件
     -add_section(section) 添加一个新的section
     -set( section, option, value) 对section中的option进行设置,需要调用write将内容写入配置文件。








程序如下:


#/usr/bin/python



import ConfigParser
import string, os, sys


cf = ConfigParser.ConfigParser()


cf.read("test.conf")


#return all section
secs = cf.sections()
print 'sections:', secs


opts = cf.options("db")
print 'options:', opts


kvs  = cf.items("db")
print 'db:', kvs


#read by type
db_host = cf.get("db", "db_host")
db_port = cf.getint("db", "db_port")
db_user = cf.get("db", "db_user")
db_pass = cf.get("db", "db_pass")


#read int 
threads = cf.getint("concurrent", "thread")
processors = cf.getint("concurrent", "processor")


print "db_host:", db_host
print "db_port:", db_port
print "db_user:", db_user
print "db_pass:", db_pass


print "thread:", threads
print "processor:", processors




#modify one value and write to file
cf.set("db", "db_pass", "xgmtest")
cf.write(open("test.conf", "w"))
<think>嗯,用户想了解Python中的configparser模块的语法和功能。首先,我得确认自己对configparser的了解是否正确。这个模块主要用于处理配置文件,通常是INI格式的文件。对吗?对的,INI文件分section,每个section下有键值对。 那用户可能想知道怎么用这个模块来读写配置文件。需要分步骤介绍,比如如何创建ConfigParser对象,读取文件,获取section和option,还有写入配置。可能还要提到一些注意事项,比如数据类型的问题,因为configparser默认处理的是字符串,需要手动换其他类型。 另外,用户可能不太清楚INI文件的结构,可能需要举个例子说明。比如典型的INI文件有[DEFAULT]这样的section,然后是键=值的形式。还要注意大小写的问题,默认情况下section名是大小写敏感的,而option名会被换为小写吗?或者是否区分大小写,可能需要查证。比如,ConfigParser默认情况下option名是大小写不敏感的,会为小写,但可以通过optionxform方法修改行为。这部分可能需要提到。 还有,如何处理注释?INI文件的注释通常以;或者#开头,configparser在读取时会忽略这些注释,但在写入时如何添加注释呢?可能需要说明,configparser在写入时不会保留原有注释,这算是一个限制。 另外,异常处理也很重要,比如当section或option不存在时,会抛出NoSectionError或NoOptionError,用户可能需要用try-except来捕获这些异常,或者使用get方法的fallback参数。 还有,DEFAULT section的特殊作用,当其他section没有某个option时,会去DEFAULT里找。这点需要强调,因为有时候用户可能不知道这个特性。 接下来,我需要组织这些点,按照用户的要求,结构清晰,分步骤说明。可能需要先介绍功能,再讲基本用法,然后语法示例,最后注意事项。 可能需要检查一下是否遗漏了重要方法,比如sections(), options(section), has_section(), has_option(), add_section(), remove_section()等。还有如何设置值,写入文件,比如set()方法和write()方法。 还有,是否支持插值,比如在值中引用其他变量。例如,在ConfigParser中,可以设置option=%(other_option)s,这样可以使用插值来引用其他值。不过这可能涉及到interpolation的参数,需要说明SafeConfigParser和原始ConfigParser的区别,不过在Python 3中可能已经统一了?需要确认当前版本的configparser是否有变化。比如,在Python3中,ConfigParser默认使用插值,但可以通过interpolation参数禁用,比如使用BasicInterpolation或ExtendedInterpolation,或者None。这可能是一个需要注意的地方,避免用户在使用时出现意外的插值解析错误。 最后,可能需要给出一个完整的示例,从创建、读取、修改到写入的流程,帮助用户直观理解。同时提醒数据类型换的问题,比如使用getint(), getfloat(), getboolean()等方法来自动换类型,或者自己用eval处理,但后者可能有安全风险。 整理这些思路后,应该能覆盖用户的主要需求,确保回答正确且实用。</think>### 一、`configparser` 模块功能简介 `configparser` 是 Python 标准库中用于解析 **INI 格式配置文件** 的模块,主要功能包括: - **读写配置文件**:支持 `.ini` 格式文件的读取、修改和创建 - **结构化存储**:通过 `Section`(区块)和 `Key-Value`(键值对)组织配置内容 - **数据类型支持**:自动处理布尔值、整数、浮点数(需显式调用方法) - **插值功能**:支持引用其他键值(例如 `%(name)s`) --- ### 二、INI 文件基础语法 ```ini [DEFAULT] # 默认区块(特殊作用,其他区块可继承其键值) server_ip = 127.0.0.1 [database] port = 3306 user = admin password = secret active = true # 布尔值示例 [paths] data_dir = /var/data log_dir = %(data_dir)s/logs # 插值引用示例 ``` --- ### 三、核心语法与示例代码 #### 1. 读取配置文件 ```python import configparser # 创建 ConfigParser 对象 config = configparser.ConfigParser() # 读取文件 config.read('config.ini') # 获取所有区块名(不包含 DEFAULT) sections = config.sections() # 输出: ['database', 'paths'] # 获取特定键值 db_port = config.getint('database', 'port') # 自动换为 int active = config.getboolean('database', 'active') # 换为 bool log_dir = config.get('paths', 'log_dir') # 输出: /var/data/logs ``` #### 2. 修改与写入配置 ```python # 添加新区块 config.add_section('debug') config.set('debug', 'level', 'info') # 修改现有值 config.set('database', 'user', 'new_admin') # 保存到文件 with open('new_config.ini', 'w') as f: config.write(f) ``` #### 3. 检查配置存在性 ```python if config.has_section('database'): print("数据库配置存在") if config.has_option('paths', 'data_dir'): print("数据目录已配置") ``` --- ### 四、注意事项 1. **大小写敏感**:默认将键名换为小写,可通过 `config.optionxform = lambda option: option` 禁用 2. **DEFAULT 区块特性**: - 所有其他区块会自动继承 `DEFAULT` 中的键值 - 若某键不存在于当前区块,会尝试从 `DEFAULT` 查找 3. **插值安全**:避免使用来自不可信源的插值(存在代码注入风险) 4. **类型处理**: - 显式使用 `getint()`, `getboolean()`, `getfloat()` 进行类型换 - 普通 `get()` 方法返回字符串 --- ### 五、典型应用场景 - 数据库连接参数管理 - 程序运行环境配置(开发/生产) - 动态调整功能开关 - 路径配置集中化管理 通过合理使用 `configparser`,可以显著提升代码的可配置性和可维护性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值