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))  # 

port2 = config.get('MySQL', 'port')
print(port2)  # 3306
print(type(port2))  # 

以数据库连接为例,介绍将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')
)

你可能感兴趣的:(python,开发语言)