Python中configparser的使用

1. configparser介绍

configparser是python自带的配置参数解析器。可以用于解析.ini文件中的配置参数。ini文件中由sections(节点)-key-value组成。

2. ini文件配置说明

[DEFAULT]
key1 = value1 

[section1] 
key1 = value1 
key2 : value2

[section2]
key1 = value1
key2 = value2
  • [DEFAULT]是特殊的节点,使用config.sections()的时候不会被输出。当调用其它节点的某key时:
    – 若其他节点中存在key,输出对应节点的key及value
    – 若其他节点中不存在key,DEFAULT中存在对应的key的话,输出DEFAULT中的key
  • [section1] 区分大小写,前后空格不会被处理,同一个配置文件中不允许重复。
  • key:不区分大小写,前后空格会被处理,同一个section中不允许重复,不可以跨。key和value可以使用 key = value 也可以使用 key : value

3. 读取配置示例

(1)config.ini

[DEFAULT]
port = 8080

[MySQL]
host = 172.xxx.xxx.xxx
port = 3306
user = root
password = ******
db = bgp_routing
charset = utf8

(2)读取配置文件config.read()

import configparser
from pathlib import Path

config_dir = r'./config.ini' # 配置文件地址
config = configparser.ConfigParser()
config.read(config_dir, encoding='utf-8')  # 从文件中读取配置信息

(3)获取配置文件中的key和value

config的key和value的获取有两种方式:

  • config.get()函数读取:默认返回str
  • 字典读取:默认返回str

注:这里无论是通过上述哪种方式获取value,返回的数据类型均为str。因此,如果需要其他类型(如端口需要int型),需要使用强制类型转化。

以下给出具体示例:

# 获取所有的节点sections
print(config.sections())  # ['MySQL']

port1 = config['MySQL']['port'] 
print(port1)  # 3306
print(type(port1))  # <class 'str'>

port2 = config.get('MySQL', 'port')
print(port2)  # 3306
print(type(port2))  # <class 'str'>

以数据库连接为例,介绍将config返回的str类型转化为int类型:

import pymysql

conn = pymysql.connect(
    host=config.get('MySQL', 'host'),
    port=int(config.get('MySQL', 'port')),  # 将port转化为int型!!!
    user=config.get('MySQL', 'user'),
    password=config.get('MySQL', 'password'),
    db=configg.get('MySQL', 'db'),
    charset=config.get('MySQL', 'charset')
)
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值