Python如何使用ConfigParser读取配置文件

作者:迎风而来 时间:2023-11-03 03:05:30 

在项目过程中,需要设置各种IP和端口号信息等,如果每次都在源程序中更改会很麻烦(因为每次都要重启项目重新加载配置信息),因此将需要修改的参数写在配置文件(或者数据库)中,每次只需修改配置文件,就可以实现同样的目的。Python 标准库的 ConfigParser 模块提供一套 API 来读取和操作配置文件。因此在程序开始位置要导入该模块,注意区分是python2还是python3,python3有一些改动

import ConfigParser #python 2.x
import configparser #python 3.x

配置文件的格式

  • a) 配置文件中包含一个或多个 section, 每个 section 有自己的 option;

  • b) section 用 [sect_name] 表示,每个option是一个键值对,使用分隔符 = 或 : 隔开;

  • c) 在 option 分隔符两端的空格会被忽略掉

  • d) 配置文件使用 # 和 ; 注释

一个简单的配置文件样例 config.conf


# database source
[db]   # 对应的是一个section
host = 127.0.0.1  # 对应的是一个option键值对形式
port = 3306
user = root
pass = root

# ssh
[ssh]
host = 192.168.10.111
user = sean
pass = sean

ConfigParser 的基本操作

a) 实例化 ConfigParser 并加载配置文件

cp = ConfigParser.SafeConfigParser()
cp.read('config.conf')

b) 获取 section 列表、option 键列表和 option 键值元组列表

print('all sections:', cp.sections()) # sections: ['db', 'ssh']
print('options of [db]:', cp.options('db')) # options of [db]: ['host', 'port', 'user', 'pass']
print('items of [ssh]:', cp.items('ssh')) # items of [ssh]: [('host', '192.168.10.111'), ('user', 'sean'), ('pass', 'sean')]

c) 读取指定的配置信息

print('host of db:', cp.get('db', 'host')) # host of db: 127.0.0.1
print('host of ssh:', cp.get('ssh', 'host')) # host of ssh: 192.168.10.111

d) 按类型读取配置信息:getint、 getfloat 和 getboolean

print(type(cp.getint('db', 'port'))) # <type 'int'>

e) 判断 option 是否存在

print(cp.has_option('db', 'host')) # True

f) 设置 option

cp.set('db', 'host','192.168.10.222')

g) 删除 option

cp.remove_option('db', 'host')

h) 判断 section 是否存在

print(cp.has_section('db')) # True

i) 添加 section

cp.add_section('new_sect')

j) 删除 section

cp.remove_section('db')

k) 保存配置,set、 remove_option、 add_section 和 remove_section 等操作并不会修改配置文件,write 方法可以将 ConfigParser 对象的配置写到文件中

cp.write(open('config.conf', 'w'))
cp.write(sys.stdout)

来源:https://www.cnblogs.com/sui776265233/p/13299490.html

标签:Python,ConfigParser,读取,配置,文件
0
投稿

猜你喜欢

  • mysql批量插入BulkCopy的实现

    2024-01-28 14:53:12
  • mysql中如何判断是否支持分区

    2024-01-19 18:00:57
  • Python实现查找二叉搜索树第k大的节点功能示例

    2023-12-17 04:40:09
  • Python subprocess模块学习总结

    2022-04-29 02:17:40
  • 使用CSS3和RGBa创建超酷的按钮

    2009-06-02 12:41:00
  • Python利用pandas处理Excel数据的应用详解

    2022-02-08 16:25:02
  • python基础之引用和匿名函数

    2023-01-13 11:52:42
  • win10环境安装kettle与linux环境安装kettle的详细过程

    2022-12-17 09:58:21
  • 设计师的底线

    2009-05-06 12:51:00
  • 一小时学会TensorFlow2之基本操作1实例代码

    2023-03-01 23:58:10
  • 使用Python中PIL库给图片添加文本水印

    2021-09-07 19:09:52
  • 关于django连接mysql数据库并进行数据库的创建的问题

    2024-01-22 04:50:12
  • pygame游戏之旅 调用按钮实现游戏开始功能

    2023-04-19 06:36:44
  • python执行shell获取硬件参数写入mysql的方法

    2024-01-26 15:56:04
  • 仿阿里巴巴搜索导航设计效果

    2008-04-15 15:01:00
  • SQL Server 2005作业设置定时任务

    2024-01-27 13:02:59
  • 用户 jb51net 登录失败。原因: 该帐户的密码必须更改

    2024-01-13 05:58:46
  • Go语言常用条件判断空值逻辑的使用

    2024-04-25 15:10:07
  • 很有意思的SQL多行数据拼接

    2011-11-03 17:08:29
  • Python基于scrapy采集数据时使用代理服务器的方法

    2022-06-03 08:37:04
  • asp之家 网络编程 m.aspxhome.com