当前位置: 首页 > news >正文

Python-配置模块configparser使用指南

configparser 是 Python 标准库中的模块,用于处理配置文件(如 .ini 文件)。它适合管理程序的配置信息,比如数据库连接参数、应用程序设置等。

1. 配置文件的基本结构

配置文件通常是 .ini 格式,由 节(Section) 和 键值对(Key-Value Pairs) 组成:

[DEFAULT]
AppName = MyApp
Version = 1.0[Database]
Host = localhost
Port = 5432
User = admin
Password = secret[Logging]
Level = DEBUG
FilePath = /var/log/myapp.log

2. 安装 configparser

configparser 是 Python 内置模块,无需安装。直接导入即可:

import configparser

3. 读取配置文件

ConfigParser 对象可用于读取和操作配置文件。

示例:读取配置文件
import configparser# 创建 ConfigParser 对象
config = configparser.ConfigParser()# 读取配置文件
config.read('config.ini')# 访问 DEFAULT 节中的键值
app_name = config['DEFAULT']['AppName']
version = config['DEFAULT']['Version']print(f"App Name: {app_name}, Version: {version}")# 访问 Database 节中的键值
db_host = config['Database']['Host']
db_port = config['Database']['Port']print(f"Database Host: {db_host}, Port: {db_port}")# 使用 get 方法访问数据(带类型转换)
db_port = config.getint('Database', 'Port')  # 转换为整数
print(f"Database Port (as int): {db_port}")

4. 检查配置文件内容

可以检查某些节或键是否存在:

# 检查某个节是否存在
if 'Database' in config:print("Database section exists.")# 检查某个键是否存在
if 'User' in config['Database']:print("User key exists in Database section.")

5. 修改配置文件

可以直接修改 ConfigParser 对象的内容,然后将其写入文件。

示例:修改和保存配置文件
# 修改配置项
config['Database']['Host'] = '127.0.0.1'
config['Database']['User'] = 'new_user'# 添加新的节和配置
config['NewSection'] = {'Key1': 'Value1','Key2': 'Value2'
}# 保存到文件
with open('config.ini', 'w') as configfile:config.write(configfile)

6. 删除配置

可以删除整个节或某个键。

示例:删除节和键
# 删除某个键
config.remove_option('Database', 'Password')# 删除某个节
config.remove_section('Logging')# 保存修改
with open('config.ini', 'w') as configfile:config.write(configfile)

7. 使用默认值

DEFAULT 节用于设置默认值,其他节可以继承这些默认值。

示例:默认值的继承
[DEFAULT]
Timeout = 30[Service1]
Host = service1.local[Service2]
Host = service2.local# 获取 Service1 和 Service2 的 Timeout 值
timeout_service1 = config['Service1']['Timeout']  # DEFAULT 节的值
timeout_service2 = config['Service2']['Timeout']print(f"Service1 Timeout: {timeout_service1}, Service2 Timeout: {timeout_service2}")

8. 支持的数据类型

configparser 支持以下常见类型的解析和转换:

  • get(): 获取字符串值
  • getint(): 获取整数值
  • getfloat(): 获取浮点数值
  • getboolean(): 获取布尔值(如 True、False)
示例:读取不同数据类型
timeout = config.getint('DEFAULT', 'Timeout')is_debug = config.getboolean('Logging', 'Level')
print(f"Timeout: {timeout}, Is Debug Mode: {is_debug}")

9. 动态创建配置文件

可以从头开始创建一个新的配置文件。

示例:动态生成配置文件
# 创建新的 ConfigParser 对象
new_config = configparser.ConfigParser()# 添加节和配置
new_config['DEFAULT'] = {'AppName': 'NewApp', 'Version': '2.0'}new_config['UserSettings'] = {'Theme': 'Dark', 'FontSize': '12'}new_config['Database'] = {'Host': 'db.local','Port': '3306','User': 'admin','Password': 'password123'
}# 写入文件
with open('new_config.ini', 'w') as configfile:new_config.write(configfile)

10. 处理带注释的配置文件

configparser 会忽略 # 和 ; 开头的注释。

示例:带注释的配置文件
[DEFAULT]# 这是一个注释
AppName = MyApp; 内联注释
Version = 1.0
# 解析时会自动忽略注释:app_name = config['DEFAULT']['AppName']
print(app_name)  # 输出:MyApp

11. 扩展功能:自定义解析器

你可以继承 ConfigParser 类,重写方法以实现自定义行为。

示例:忽略大小写的键
class CustomConfigParser(configparser.ConfigParser):def optionxform(self, optionstr):return optionstr.lower()  # 转为小写custom_config = CustomConfigParser()custom_config.read('config.ini')# 无论大小写,均可访问
print(custom_config['Database']['HOST'])  
# 等同于 custom_config['Database']['host']

12. 异常处理

使用 configparser 时可能会遇到异常,例如文件缺失或键不存在。

常见异常:
  • configparser.NoSectionError: 节不存在
  • configparser.NoOptionError: 键不存在
  • configparser.ParsingError: 配置文件格式错误
示例:捕获异常
try:value = config['NonExistentSection']['Key']
except configparser.NoSectionError:print("Section does not exist!")except configparser.NoOptionError:print("Key does not exist!")

configparser 模块非常适合管理简单的配置文件,提供了灵活的 API 支持读取、修改和保存配置文件。在复杂应用中,它可以作为配置管理工具的一部分。

相关文章:

Python-配置模块configparser使用指南

configparser 是 Python 标准库中的模块,用于处理配置文件(如 .ini 文件)。它适合管理程序的配置信息,比如数据库连接参数、应用程序设置等。 1. 配置文件的基本结构 配置文件通常是 .ini 格式,由 节(Sec…...

C++的HDF5库将h5图像转为tif格式:szip压缩的图像也可转换

本文介绍基于C 语言的hdf5库与gdal库,将.h5格式的多波段HDF5图像批量转换为.tif格式的方法;其中,本方法支持对szip压缩的HDF5图像(例如高分一号卫星遥感影像)加以转换。 将HDF5图像批量转换为.tif格式,在部…...

【JAVA】Java第十三节:String类(String相关方法,以及StrinBuftrer , StringBulder相关方法)

本文详细介绍了String类以及常用的String相关方法,以及StrinBuftrer , StringBulder相关方法的使用,建议有印象即可,不需要都记住,使用时去查取即可 一、创建一个String类型的变量 我们平时创建String类型的变量一般是第一种形式…...

WordPress安装或访问时出现数据库连接错误的处理方式

一、在安装时出现数据库连接错误 1、如果数据库名称、用户名或密码错误,或者主机设置不正确(如数据库服务器不是在本地localhost,而是在远程服务器,需要正确填写远程服务器的 IP 地址或域名),就会导致连接错…...

JAVA-面向对象基础

文章目录 概要封装多态抽象类接口内部类为什么需要内部类 概要 面向对象是一种编程范式或设计哲学,它将软件系统设计为由多个对象组成,这些对象通过特定的方式相互作用 封装 将数据和操作数据的方法封装在一个类中,并通过访问修饰符控制对…...

[Java]项目入门

这篇简单介绍一些入门的有关项目和行业的知识,并带着实现一个小项目。便于已经编程入门的各位准备进阶到下一个阶段。 先大致地介绍,一个完整的项目(不看客户端、服务端的分类)基本可以划分为三部分: 1.前端。比如你现在看到的CSDN页面就是一…...

opencv Mat To Heif

高效率图像文件格式(英语:High Efficiency Image File Format, HEIF;也称高效图像文件格式)是一个用于单张图像或图像序列的文件格式。它由运动图像专家组(MPEG)开发,并在MPEG-H Part 12&#x…...

二刷代码随想录第24天

93. 复原 IP 地址 确定函数is_ip的实现细节&#xff0c;start不能超过end&#xff0c;没有0开头的非0数字&#xff0c;每个字符都在0-9之间,每段字符小于255在原字符串s上做操作会更简单一些 class Solution { public:vector<string> result;vector<string> rest…...

Java设计模式之状态模式架构高扩展的订单状态管理

🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/literature?__c=1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编程,高并发设计,Springboot和微服务,熟悉Linux,ESXI虚拟化以及云原生Docker和K8s…...

Yagmail邮件发送库:如何用Python实现自动化邮件营销?

目录 一、Yagmail简介 二、安装Yagmail 三、基本使用示例 1. 发送简单文本邮件 2. 发送HTML邮件 3. 发送带有附件的邮件 4. 多收件人处理 5. 自定义邮件头 四、高级功能 1. SMTP配置 2. 邮件模板 3. OAuth2认证 五、自动化邮件营销案例 六、错误处理和调试 七、…...

李宏毅深度学习-Pytorch Tutorial2

什么是张量&#xff1f; 张量&#xff08;Tensor&#xff09;是深度学习和机器学习中一个非常基础且重要的概念。在数学上&#xff0c;张量可以被看作是向量和矩阵的泛化。简单来说&#xff0c;张量是一种多维数组&#xff0c;它可以表示标量&#xff08;0维&#xff09;、向量…...

SaaS财务软件:赋能企业数字化转型

在数字化浪潮的推动下&#xff0c;企业财务管理正逐步迈向智能化、高效化的新阶段。在这个过程中&#xff0c;SaaS财务软件应运而生&#xff0c;成为许多企业的首选。以易舟云财务软件为例&#xff0c;这款软件不仅集成了众多先进的财务管理功能&#xff0c;而且在用户体验上做…...

FPGA实战篇(按键控制LDE实验)

1.按键简介 按键开关是一种电子开关&#xff0c;属于电子元器件类。我们的开发板上有两种按键开关&#xff1a;第一种是本实验所使用的轻触式按键开关&#xff0c;简称轻触开关。使用时以向开关的操作方向施加压力使内部电路闭合接通&#xff0c;当撤销压力时开关断开&#xff…...

在Ubuntu-22.04 [WSL2]中配置Docker

文章目录 0. 进入Ubuntu-22.041. 更新系统软件包2. 安装Docker相关依赖包3. 添加Docker官方GPG密钥4. 添加Docker软件源5. 安装Docker Engine5.1 更新软件包列表5.2 安装Docker相关软件包 6. 验证Docker安装是否成功6.1 查看Docker版本信息6.2 启动Docker6.3 配置镜像加速器6.4…...

ACM:均分纸牌

主要思路 整体思路概述&#xff1a; 本题旨在解决给定N堆纸牌&#xff08;纸牌总数是N的倍数&#xff09;&#xff0c;通过按照特定移牌规则移动纸牌&#xff0c;找出用最少移动次数使每堆纸牌数量相等的方法。程序采用了一种逐步调整的思路&#xff0c;先计算出每堆纸牌应有的…...

ThreadFactory

ThreadFactory 是 Java 中一个用于创建线程的接口&#xff0c;它可以自定义线程的创建过程&#xff0c;例如线程的名称、优先级、是否为守护线程等。它是 java.util.concurrent 包的一部分&#xff0c;通常与线程池&#xff08;ThreadPoolExecutor&#xff09;一起使用。 线程…...

WEB开发: Node.js路由之由浅入深(一) - 全栈工程师入门

作为一个使用Node.js多年的开发者&#xff0c;我已经习惯于用Node.js写一些web应用来为工作服务&#xff0c;因为实现快速、部署简单、自定义强。今天我们一起来学习一个全栈工程师必备技能&#xff1a;web路由。&#xff08;观看此文的前提是默认你已经装好nonde.js了&#xf…...

NES游戏机项目制作笔记(未完成)

24年12月1日晚记——在网上找项目学习的时候发现一个有意思的项目&#xff0c;准备靠这个应用一些STM32的高级功能。值得提醒的是——目的在于学习不可贪杯&#xff0c;注意效率 01 根据项目需求分析 为确保充分考虑每一个细节&#xff0c;并且让自己高效的完成项目制作&#…...

云服务器部署upload-labs-docker(文件上传靶场)环境 以及相关报错问题

环境的搭建 准备&#xff1a;云服务器&#xff08;本地的linux服务器&#xff08;版本最好不要是老的不然不兼容docker&#xff09;&#xff09; f8x配置docker环境&#xff1a; https://github.com/ffffffff0x/f8x 一键配置 docker拉取file-labs靶场 https://github.com…...

Elasticsearch入门之HTTP基础操作

RESTful REST 指的是一组架构约束条件和原则。满足这些约束条件和原则的应用程序或设计就是 RESTful。Web 应用程序最重要的 REST 原则是&#xff0c;客户端和服务器之间的交互在请求之间是无状态的。从客户端到服务器的每个请求都必须包含理解请求所必需的信息。如果服务器在…...

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…...

解决Ubuntu22.04 VMware失败的问题 ubuntu入门之二十八

现象1 打开VMware失败 Ubuntu升级之后打开VMware上报需要安装vmmon和vmnet&#xff0c;点击确认后如下提示 最终上报fail 解决方法 内核升级导致&#xff0c;需要在新内核下重新下载编译安装 查看版本 $ vmware -v VMware Workstation 17.5.1 build-23298084$ lsb_release…...

Opencv中的addweighted函数

一.addweighted函数作用 addweighted&#xff08;&#xff09;是OpenCV库中用于图像处理的函数&#xff0c;主要功能是将两个输入图像&#xff08;尺寸和类型相同&#xff09;按照指定的权重进行加权叠加&#xff08;图像融合&#xff09;&#xff0c;并添加一个标量值&#x…...

【算法训练营Day07】字符串part1

文章目录 反转字符串反转字符串II替换数字 反转字符串 题目链接&#xff1a;344. 反转字符串 双指针法&#xff0c;两个指针的元素直接调转即可 class Solution {public void reverseString(char[] s) {int head 0;int end s.length - 1;while(head < end) {char temp …...

Ascend NPU上适配Step-Audio模型

1 概述 1.1 简述 Step-Audio 是业界首个集语音理解与生成控制一体化的产品级开源实时语音对话系统&#xff0c;支持多语言对话&#xff08;如 中文&#xff0c;英文&#xff0c;日语&#xff09;&#xff0c;语音情感&#xff08;如 开心&#xff0c;悲伤&#xff09;&#x…...

Axios请求超时重发机制

Axios 超时重新请求实现方案 在 Axios 中实现超时重新请求可以通过以下几种方式&#xff1a; 1. 使用拦截器实现自动重试 import axios from axios;// 创建axios实例 const instance axios.create();// 设置超时时间 instance.defaults.timeout 5000;// 最大重试次数 cons…...

Android15默认授权浮窗权限

我们经常有那种需求&#xff0c;客户需要定制的apk集成在ROM中&#xff0c;并且默认授予其【显示在其他应用的上层】权限&#xff0c;也就是我们常说的浮窗权限&#xff0c;那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...

代理篇12|深入理解 Vite中的Proxy接口代理配置

在前端开发中,常常会遇到 跨域请求接口 的情况。为了解决这个问题,Vite 和 Webpack 都提供了 proxy 代理功能,用于将本地开发请求转发到后端服务器。 什么是代理(proxy)? 代理是在开发过程中,前端项目通过开发服务器,将指定的请求“转发”到真实的后端服务器,从而绕…...

HarmonyOS运动开发:如何用mpchart绘制运动配速图表

##鸿蒙核心技术##运动开发##Sensor Service Kit&#xff08;传感器服务&#xff09;# 前言 在运动类应用中&#xff0c;运动数据的可视化是提升用户体验的重要环节。通过直观的图表展示运动过程中的关键数据&#xff0c;如配速、距离、卡路里消耗等&#xff0c;用户可以更清晰…...

Razor编程中@Html的方法使用大全

文章目录 1. 基础HTML辅助方法1.1 Html.ActionLink()1.2 Html.RouteLink()1.3 Html.Display() / Html.DisplayFor()1.4 Html.Editor() / Html.EditorFor()1.5 Html.Label() / Html.LabelFor()1.6 Html.TextBox() / Html.TextBoxFor() 2. 表单相关辅助方法2.1 Html.BeginForm() …...