博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python ConfigParser 学习
阅读量:6711 次
发布时间:2019-06-25

本文共 3662 字,大约阅读时间需要 12 分钟。

【安装】
ConfigParser 是解析配置文件的第三方库,需要安装 pip install ConfigParser
 
【介绍】
ConfigParser 是用来读取配置文件(可以是.conf, .txt, .init 等格式)的包。
配置文件的格式如下:中括号“[ ]”内包含的为section。 section 下面为为option, 类似于key-value 的配置内容。
如下,[ ]内包含的 db 和 concurrent 为 section, db_host 等为option
 
[db]
db_host = 127.0.0.1
db_port = 22
db_user = root
db_pass = rootroot
 
[concurrent]
thread = 10
processor = 20
 
注意: key = value 和 key:value 两种形式都可以
 
【常见函数】
-read(filename) 直接读取配置文件内容
-sections() 得到所有的section,并以列表的形式返回
-options(section) 得到该section的所有option
-items(section) 得到该section的所有键值对
-get(section,option) 得到section中option的值,返回为string类型
-getint(section,option) 得到section中option的值,返回为int类型,还有相应的getboolean()和getfloat() 函数。
 
【用法】
1. ConfigParser 初始工作
使用ConfigParser 首选需要初始化实例,并读取配置文件:
import ConfigParsercf = ConfigParser.ConfigParser()cf.read("配置文件名")
 
2. 获取所有sections。也就是将配置文件中所有“[ ]”读取到列表中:
s = cf.sections()print 'section:', s
 
将输出(以下将均以简介中配置文件为例):section: ['db', 'concurrent']
 
3. 获取指定section 的options。即将配置文件某个section 内key 读取到列表中:
o = cf.options("db")print 'options:', o
将输出:
options: ['db_host', 'db_port', 'db_user', 'db_pass']
 
4. 获取指定section 的所有配置信息。返回列表,列表的元素是key,value 组成的元组。 (用起来不方便)
v = cf.items("db")print 'db:', v
将输出:
db: [('db_host', '127.0.0.1'), ('db_port', '22'), ('db_user', 'root'), ('db_pass', 'rootroot')]
 
5. 按照类型读取指定section 的option 信息。同样的还有getint、getfloat、getboolean。
#可以通过get(section,option)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")
 
# 按照类型读取出来
threads = cf.getint("concurrent", "thread")processors = cf.getint("concurrent", "processor") print "db_host:", db_hostprint "db_port:", db_portprint "db_user:", db_userprint "db_pass:", db_passprint "thread:", threadsprint "processor:", processors

 

将输出:
db_host: 127.0.0.1
db_port: 22
db_user: root
db_pass: rootroot
thread: 10
processor: 20
 
注: 当查找不到指定的 section 或者 option 时,会抛出异常:
raise NoSectionError(section)
ConfigParser.NoSectionError: No section: 'dbs'
 
raise NoOptionError(option, section)
ConfigParser.NoOptionError: No option 'db_hosts' in section: 'db'
 
所以,在用 get(section,option) (getint,getfloat,getboolean 同) 时:
a. 要么包含在try...except 语句中,主动捕获异常
b. 要么先判断是否有该指定的 section 或 option:
if parser.has_section('section'): #判断 section 是否存在
dosomething
 
if parser.has_option('section','option'): #判断 option 是否存在
dosomething
 
6. 设置默认值 DEFAULT
如果配置文件中存在一个名为 DEFAULT (只能全部大写) 的 section,那么其他 section 会扩展它的 option 并且可以覆盖它的 option
 
[DEFAULT]
host = 127.0.0.1
port = 3306 [db_root]
user = root
pass = root
 
 
[db_huey]
host = 192.168.1.101
user = huey
pass = huey
 
print cp.get('db_root', 'host') # 127.0.0.1 print cp.get('db_huey', 'host') # 192.168.1.101
 
注意:当查询所有 sections 时, 显示只有两个, 即没有 DEFAULT 这个section
查询 section 里的options 时, 则多显示了两个, 即每个section 都会扩张 DEFAULT的 options
如 print parser.options('db_root')
则输出为 ['user ','pass','host','port']
 
=========================================================================================
封装成以字典返回的函数:
def configParser(config_file):  parser = ConfigParser.ConfigParser()  parser.read(config_file)  config = {}  for session in parser.sections(): #循环解析每一个section    sessionValue = {} #把每一个section下对应的所有配置都存放到一个字典里    for option in parser.options(session): #循环解析每一个section下的每一个option      sessionValue[option] = parser.get(session, option).strip()    config[session] = sessionValue #最后把所有的section(字典)再存放到一个大的字典里  return config

 

print configParser('../config.txt')print configParser('../config.txt').get('db').get('db_host')
 
输出:
{
'concurrent': {'processor': '20', 'thread': '10'},
'db': {'db_pass': 'rootroot', 'db_user': 'root', 'db_host': '127.0.0.1', 'db_port': '22'}
}
127.0.0.1
 

转载于:https://www.cnblogs.com/tomweng/p/6776205.html

你可能感兴趣的文章
区块链是一种用一种不可变的形式存储数字信息
查看>>
【须弥SUMERU】宜信分布式安全服务编排实践
查看>>
docker笔记2-镜像与容器
查看>>
Node.js this指针指向module.exports、global、实例,指针显式、隐式传递与绑定与优先级...
查看>>
H5以及Node读取excel
查看>>
Nginx基础篇(1)- Nginx的快速搭建和基本参数
查看>>
opencv python K-Means聚类
查看>>
从DevOps到AIOps,阿里如何实现智能化运维?
查看>>
Vue中的RouteMock实现思路及其问题
查看>>
前端每日实战:25# 视频演示如何用纯 CSS 创作一个慧星拖尾效果的 loader 动画...
查看>>
2018年第18周-Java语言思想-并发
查看>>
Node.js EventEmitter解读
查看>>
innodb事务隔离级别及实现机制
查看>>
分布式服务Dubbo的前世今生
查看>>
聊聊 WebRTC 网关服务器 2:如何选择 PeerConnection 方案?
查看>>
node项目部署杂记
查看>>
JavaScript由浅及深敲开原型链(二)
查看>>
关于CSS的个人理解
查看>>
java多线程(6)线程池
查看>>
WPF:Animation动画--CustomAnimation自定义动画(1)
查看>>