【Python】ConfigParser模块

简介: 一 前言    最近研究备份恢复MySQL数据库实例,老的数据配置和新的实例的my.cnf 配置不统一,依赖backup-my.cnf 来判断innodb_data_file_path 参数是否修改修改。
一 前言
   最近研究备份恢复MySQL数据库实例,老的数据配置和新的实例的my.cnf 配置不统一,依赖backup-my.cnf 来判断innodb_data_file_path 参数是否修改修改。如何解析 my.cnf 呢?于是研究了Python提供ConfigParser模块。该模块可以完成针对常见的配置文件的读取和修改操作,基本满足需求。
二 如何使用
  2.1 配置文件的格式
  配置文件主要由 section区域 构成,section中可以使用option=value或option:value,来配置参数。 
  1. [section1 名称]
  2. option1=值1
  3. ....
  4. optionN=值N
  5. [section2 名称]
  6. option1=值1
  7. ....
  8. optionN=值N
  常见的 my.cnf 格式 如下
  1. [mysqld]
  2. innodb_log_files_in_group = 2
  3. innodb_page_size = 16384
  4. innodb_log_block_size = 512
  5. innodb_data_file_path = ibdata1:2G:autoextend
  6. innodb_log_file_size = 536870912
 2.2 ConfigParser 模块
  Python的ConfigParser Module定义了3个类:RawCnfigParser,ConfigParser,SafeConfigParser. 其中RawCnfigParser 是最基础的配置文件读取类,ConfigParser、SafeConfigParser基于 RawCnfigParser做了各自的拓展
  本文主要以ConfigParser类为例做介绍。ConfigParser模块的操作主要包括:
   a 初始化一个 ConfigParser实例
   b 读取配置
   c 修改配置
读取配置文件常用的方法

  1. cf.read(filename)   读取配置文件内容
  2. cf.sections()       获取所有的section,并以列表的形式返回
  3. cf.options(section) 获取指定section下所有option
  4. cf.items(section)   获取指定section下所有键值对,以元组的形式返回
  5. cf.get(section,option) 获取指定section中option的值,返回为string类型
  6. cf.getint(section,option) 获取指定section中option的值,返回为int类型
  7. cf.has_option(section,option) 检查section下是否有指定的option,有返回True,无返回 False
  8. cf.has_section(section) 检查是否有section,有返回True,无返回 False
修改配置文件常用的方法
  1. cf.add_section(section) 向配置文件中添加一个新的section
  2. cf.set(section,option,value) 对section中的option进行设置
  3. cf.remove_section(section) 删除指定的section
  4. cf.remove_option(section,option) 删除指定section中的option
  5. 注意对于修改配置文件的操作需要调用write将内容写入配置文件。
2.3 例子

点击(此处)折叠或打开

  1. #!/usr/bin/python2.6
  2. #coding:utf8
  3. import ConfigParser
  4. old_mycnf_file='backup-my.cnf'
  5. new_mycnf_file='my.cnf'
  6. cf =ConfigParser.ConfigParser()
  7. cf.read(new_mycnf_file)
  8. sec=cf.sections()
  9. print 'sections:' ,sec
  10. opts = cf.options("mysqld")
  11. print 'options:', opts
  12. kvs = cf.items("mysqld")
  13. for kv in kvs:
  14.     print kv
  15. innodb_data_file_path=cf.get('mysqld','innodb_data_file_path')
  16. innodb_log_file_size=cf.get('mysqld','innodb_log_file_size')
  17. print 'innodb_data_file_path :',innodb_data_file_path
  18. print 'innodb_log_file_size :',innodb_log_file_size
  19. print "修改之后"
  20. cf.set('mysqld','innodb_data_file_path','ibdata1:1G:autoextend')
  21. cf.write(open(new_mycnf_file, "w"))
  22. cf.read(new_mycnf_file)
  23. innodb_data_file_path=cf.get('mysqld','innodb_data_file_path')
  24. print 'innodb_data_file_path :',innodb_data_file_path
yangyiDBA:test yangyi$ python writecnf.py 
  1. sections: ['mysqld']
  2. options: ['innodb_log_files_in_group', 'innodb_page_size', 'innodb_log_block_size', 'innodb_data_file_path', 'innodb_log_file_size', 'ibdata1']
  3. ('innodb_log_files_in_group', '2')
  4. ('innodb_page_size', '16384')
  5. ('innodb_log_block_size', '512')
  6. ('innodb_data_file_path', 'ibdata1:2G:autoextend')
  7. ('innodb_log_file_size', '536870912')
  8. ('ibdata1', '2g:autoextend = ibdata1:2G:autoextend')
  9. innodb_data_file_path : ibdata1:1G:autoextend
  10. innodb_log_file_size : 536870912
  11. 修改之后
  12. innodb_data_file_path : ibdata1:1G:autoextend
三 小结
   根据ConfigParser 模块提供的函数,基本可以满足日常工作中对配置文件的修改操作。其他更详细的资料请参考 官方文档


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
3月前
|
开发者 Python
如何在Python中管理模块和包的依赖关系?
在实际开发中,通常会结合多种方法来管理模块和包的依赖关系,以确保项目的顺利进行和可维护性。同时,要及时更新和解决依赖冲突等问题,以保证代码的稳定性和可靠性
155 62
|
2月前
|
Python
Python Internet 模块
Python Internet 模块。
131 74
|
3月前
|
算法 数据安全/隐私保护 开发者
马特赛特旋转算法:Python的随机模块背后的力量
马特赛特旋转算法是Python `random`模块的核心,由松本真和西村拓士于1997年提出。它基于线性反馈移位寄存器,具有超长周期和高维均匀性,适用于模拟、密码学等领域。Python中通过设置种子值初始化状态数组,经状态更新和输出提取生成随机数,代码简单高效。
141 63
|
3月前
|
数据可视化 Python
如何在Python中解决模块和包的依赖冲突?
解决模块和包的依赖冲突需要综合运用多种方法,并且需要团队成员的共同努力和协作。通过合理的管理和解决冲突,可以提高项目的稳定性和可扩展性
|
3月前
|
Python
Python的模块和包
总之,模块和包是 Python 编程中非常重要的概念,掌握它们可以帮助我们更好地组织和管理代码,提高开发效率和代码质量
133 61
|
3月前
|
测试技术 Python
手动解决Python模块和包依赖冲突的具体步骤是什么?
需要注意的是,手动解决依赖冲突可能需要一定的时间和经验,并且需要谨慎操作,避免引入新的问题。在实际操作中,还可以结合使用其他方法,如虚拟环境等,来更好地管理和解决依赖冲突😉。
|
3月前
|
持续交付 Python
如何在Python中自动解决模块和包的依赖冲突?
完全自动解决所有依赖冲突可能并不总是可行,特别是在复杂的项目中。有时候仍然需要人工干预和判断。自动解决的方法主要是提供辅助和便捷,但不能完全替代人工的分析和决策😉。
|
1月前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
32 3
|
3月前
|
JSON Linux 数据格式
Python模块:从入门到精通,只需一篇文章!
Python中的模块是将相关代码组织在一起的单元,便于重用和维护。模块可以是Python文件或C/C++扩展,Python标准库中包含大量模块,如os、sys、time等,用于执行各种任务。定义模块只需创建.py文件并编写代码,导入模块使用import语句。此外,Python还支持自定义模块和包,以及虚拟环境来管理项目依赖。
Python模块:从入门到精通,只需一篇文章!
|
3月前
|
Python
在Python中,可以使用内置的`re`模块来处理正则表达式
在Python中,可以使用内置的`re`模块来处理正则表达式
89 5