.ini 配置文件读取

我们在编写脚本的过程中,可能涉及一些敏感信息,例如:用户信息、数据库信息、测试数据等,如果这些数据暴露在脚本中,无疑是不安全的。

将这些信息封装到配置文件,不仅测试时修改方便快捷,不用在脚本中检索要修改的数据,同时也从某种程度上保障了数据的安全。

下面我们介绍一种Python种常用的配置文件封装方法,使用Python自带的configparser模块来完成配置文件的信息读取。下面我们就来详细介绍它的用法。

一、配置文件格式

在使用之前,我们先来了解一下,配置文件.ini的格式。

.ini文件由节(section)、键(option)、值(value)三部分组成,其中item表示键值对。

节:[section];参数(items):键(option)=值(value);注解-使用分号;表示。

在配置文件中,所有的item(键值对),都以section为单位组合。可以理解为一个section就是若干组item。一般来说,一个[section]声明开始到下一个[section]之前,都为该section中的item,特殊情况时也可以使用section嵌套。

示例如下:

;comments of configparaser testing
[section1]
option1_1 = value1_1
option1_2 = value1_2

[section2]
option2_1 = 123456

二、configparser模块

python使用自带的configparser模块用来读取配置文件,配置文件的形式类似windows中的ini文件,pip直接安装,然后就可以import来使用了。

安装configparser:

pip install configparser

安装完成:
在这里插入图片描述

三、读取配置文件

1、关于配置文件路径

绝对路径:从硬盘根目录为起点到当前所在目录;
相对路径:从某个目录为起点到当前所在目录。

我们都知道,如果使用绝对路径,那么代码放在自己的电脑中,一切正常,当放在其他电脑的任意路径位置时,文件的读取就会出现异常。因此,如果我们使用相对路径,就会比较灵活。我们一般使用“…/”来表示上一级目录,“…/…/”表示上上级的目录,以此类推。

例如:
在这里插入图片描述
我们看file.py文件的路径:
绝对路径:D:\Folder\file.py
相对路径:.\Folder\file.py

2、实例

工程目录结构如下:
在这里插入图片描述
config.ini:

;comments of configparaser testing
[section1]
option1_1 = value1_1
option1_2 = value1_2

[section2]
option2_1 = 123456

代码:

import configparser
import os

# 创建实例
cf = configparser.ConfigParser()
# # 使用绝对路径,不需要os
# config_abs_path = "D:\PycharmProjects\config\config.ini"
# 获取config.ini所在目录的上一级目录,根据工程结构,也就是当前路径的上一级路径,这个根据自己的工程目录结构来获取
root_path = os.path.dirname(os.path.abspath('..'))
# 使用相对路径,拼接获得
config_path = os.path.join(root_path + '\config\config.ini')
print('----------配置文件路径:' + config_path)
# 读取配置文件
cf.read(config_path)
# 获取配置文件中所有sections
sections = cf.sections()
print('1--配置文件中所有sections:')
print(sections)
# 获取section1中所有键值对
items = cf.items('section1')
print('2--section1中所有键值对:')
print(items)
# 获取section1中所有键
options = cf.options('section1')
print('3--section1中所有键:')
print(options)
# 获取section1中option1_1的值,str
value1_1 = cf.get('section1', 'option1_1')
print('4--section1中option1_1的值,str:')
print(type(value1_1))
print(value1_1)
# 获取section2中option1_1的值,int
value2_1 = cf.getint('section2', 'option2_1')
print('5--section2中option1_1的值,int:')
print(type(value2_1))
print(value2_1)

控制台输出结果:

----------配置文件路径:D:\PycharmProjects\config\config.ini
1--配置文件中所有sections:
['section1', 'section2']
2--section1中所有键值对:
[('option1_1', 'value1_1'), ('option1_2', 'value1_2')]
3--section1中所有键:
['option1_1', 'option1_2']
4--section1中option1_1的值,str:
<class 'str'>
value1_1
5--section2中option1_1的值,int:
<class 'int'>
123456
纯c读写ini配置文件 用c/c++读写ini配置文件有不少第三方的开源库,如iniparser、libini、rwini、UltraLightINIParser等,但都不理想,往往代码较大、功能较弱、 接口使用不方便。尤其在大小写处理、前后空格、各种注释、跨平台换行符支持、带引号字符串处理、无section操作、原格式保持等方面存在问题。 现将本人精心制作的ini读写程序源码奉献给大家,纯c编写,简洁好用。支持windows和linux。 主要特点: 1、支持;和#注释符号,支持行尾注释。 2、支持带引号'或"成对匹配的字符串,提取时自动去引号。引号中可带其它引号或;#注释符。 3、支持无section或空section(名称为空)。 4、支持10、16、8进制数,0x开头为16进制数,0开头为8进制。 5、支持section、key或=号前后带空格。 6、支持\n、\r、\r\n或\n\r换行格式。 7、不区分section、key大小写,但写入时以新串为准,并保持其大小写。 8、新增数据时,若section存在则在该节最后一个有效数据后添加,否则在文件尾部添加。 9、支持指定key所在整行删除,即删除该键值,包括注释。 10、可自动跳过格式错误行,修改时仍然保留。 11、修改时保留原注释:包括整行注释、行尾注释(包括前面空格)。 12、修改时保留原空行。以上三点主要是尽量保留原格式。 不足之处: 1、不支持单key多value(逗号分割),只能一次性提取后自行处理。 2、不支持同名重复section和key。(重复section可视为错误,重复key则可能造成分歧) 3、不能提取所有section或key名称。 使用只需两个文件inirw.h、inirw.c,另有测试程序和工程文件,支持windows和linux。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值