Python 读取配置文件 configparser 使用方法

configparser模块可方便读取.ini配置文件,支持节、键、值结构,适用于数据库、日志等设置管理。1. 创建ConfigParser对象并加载文件;2. 使用get、getint、getboolean等方法读取对应类型值;3. 通过has_section、has_option或in操作符检查节或选项存在性;4. 可动态修改配置并用set添加新内容;5. 调用write方法将更改写回文件。建议使用绝对路径避免读取错误。

python 读取配置文件 configparser 使用方法

Python 中使用 configparser 模块读取配置文件非常方便,尤其适用于 .ini 格式的配置文件。这类文件结构清晰,适合存储应用程序的设置信息,比如数据库连接、日志路径、API 密钥等。

配置文件格式(.ini)

configparser 支持标准的 INI 文件格式,由节(section)、键(key)和值(value)组成。例如,创建一个名为 config.ini 的文件:

[database]host = localhostport = 5432user = adminpassword = secret

[logging]level = DEBUGfile = app.log

[features]enable_cache = truemax_retries = 3

读取配置文件

使用 configparser 读取上述配置文件的基本步骤如下:

导入模块并创建 ConfigParser 对象,调用 read() 方法加载文件。

from configparser import ConfigParser

config = ConfigParser()config.read(‘config.ini’)

读取指定节中的值

host = config.get(‘database’, ‘host’)port = config.getint(‘database’, ‘port’) # 自动转为整数password = config.get(‘database’, ‘password’)

获取布尔值(会自动识别 true/false, yes/no, on/off)

cache_enabled = config.getboolean(‘features’, ‘enable_cache’)

立即学习“Python免费学习笔记(深入)”;

print(host) # 输出: localhostprint(port) # 输出: 5432print(cache_enabled) # 输出: True

检查节或选项是否存在

在读取前判断节或键是否存在,可避免 KeyError 异常。

if config.has_section(‘database’): if config.has_option(‘database’, ‘host’): print(config.get(‘database’, ‘host’))

或者直接用 in 操作符:

if ‘database’ in config: if ‘host’ in config[‘database’]: print(config[‘database’][‘host’])

修改和写入配置文件

可以动态修改配置,并保存回文件。

# 修改现有值config.set(‘logging’, ‘level’, ‘INFO’)

添加新节

if not config.has_section(‘server’):config.add_section(‘server’)config.set(‘server’, ‘host’, ‘0.0.0.0’)config.set(‘server’, ‘port’, ‘8000’)

写入文件

with open(‘config.ini’, ‘w’) as f:config.write(f)

基本上就这些。configparser 使用简单,适合中小型项目管理配置。注意读取时类型转换要用 getint、getboolean 等方法,避免手动处理出错。文件路径要确保正确,建议使用绝对路径或配合 os.path 处理相对路径。

以上就是Python 读取配置文件 configparser 使用方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1381937.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 23:27:42
下一篇 2025年12月14日 23:27:51

相关推荐

  • python如何对电脑进行清屏

    在Python中实现清屏操作需根据操作系统选择方法:Windows使用os.system(‘cls’),Linux/macOS使用os.system(‘clear’),跨平台可写为os.system(‘cls’ if os.na…

    好文分享 2025年12月14日
    000
  • Python 解释器的几种常见实现

    CPython是官方标准实现,用C编写,支持广泛但多线程受GIL限制;2. Jython将Python编译为Java字节码,适用于JVM平台并可调用Java库,但不支持C扩展且版本更新慢;3. IronPython运行在.NET平台,支持与C#交互,适合Windows和.NET集成,同样不兼容多数C…

    2025年12月14日
    000
  • 如何实现python中lower函数?

    答案是可以通过遍历字符并利用ASCII码转换实现类似lower()的功能:遍历字符串,判断字符是否为大写字母(’A’到’Z’),若是则将其ASCII值加32转为小写,最终拼接成新字符串返回。 在 Python 中,lower() 函数用于将字符串中的所…

    2025年12月14日
    000
  • Python 内置 Exception 类与 BaseException 的区别

    BaseException是所有异常的基类,包含SystemExit、KeyboardInterrupt等控制流异常;Exception继承自BaseException,涵盖常规错误如ValueError、TypeError;默认except捕获Exception及其子类,不包括BaseExcept…

    2025年12月14日
    000
  • Python 环境的轻量化管理技巧

    使用 venv 创建独立环境,结合 pip 精确管理依赖,pipx 隔离工具包,避免冗余安装,保持环境轻量,提升开发与部署效率。 在 Python 开发中,环境管理是确保项目依赖隔离、避免版本冲突的关键环节。轻量化管理不仅能提升开发效率,还能简化部署流程。核心思路是:按需创建最小化环境,精准控制依赖…

    2025年12月14日
    000
  • 如何自定义Python库创建和使用?

    先创建模块文件如math_utils.py并定义函数,再通过import导入使用;功能增多时可组织为包,含__init__.py的文件夹即为包,最后可用setup.py安装自定义库。 想在Python中自定义库并使用它,其实并不复杂。只要把代码组织成模块或包的形式,就能像第三方库一样导入和调用。下面…

    2025年12月14日
    000
  • python中如何在静态图像中人脸检测?

    使用OpenCV和Haar级联分类器可快速实现人脸检测。1. 安装OpenCV库;2. 加载haarcascade_frontalface_default.xml模型;3. 读取图像并转为灰度图;4. 调用detectMultiScale检测人脸,设置scaleFactor、minNeighbors…

    2025年12月14日
    000
  • python中序列化JSON

    答案:Python通过json模块实现序列化与反序列化。使用json.dumps()将Python对象转为JSON字符串,配合ensure_ascii=False和indent=2可支持中文并格式化输出;用json.dump()将数据直接写入JSON文件;反序列化时,json.loads()用于解析…

    2025年12月14日
    000
  • python线程中deque如何使用?

    答案:deque在Python中线程安全仅限单个操作如append、popleft,复合操作需加锁,多线程推荐使用queue.Queue。 在Python多线程环境中,deque(双端队列)来自 collections 模块,虽然它是线程安全的,但仅限于某些操作。理解这一点对正确使用很关键。 deq…

    2025年12月14日
    000
  • Python 异常处理在多线程环境中的注意事项

    子线程异常无法被主线程直接捕获,需在子线程内处理或通过队列、Future等机制传递异常信息。1. 每个线程独立运行,未捕获的异常仅终止该线程;2. 可使用queue.Queue将异常传回主线程;3. 推荐concurrent.futures模块,其Future.result()会重新抛出异常;4. …

    2025年12月14日
    000
  • 如何使用python中schedule模块?

    schedule模块用于Python中定时执行任务,如每5分钟或每天指定时间运行函数。通过schedule.every().time.do(job)设置任务,需配合while循环和time.sleep()持续检查执行时机,支持按秒、分、小时、天、周等周期调度。可使用schedule.cancel_j…

    2025年12月14日
    000
  • python中字典按key值排序的实现方法

    使用sorted()函数可对字典按键排序,示例中按key字母升序输出新字典,支持逆序、数值型key等场景,无需额外模块,原字典不变。 在 Python 中,字典本身是无序的(Python 3.7+ 后保持插入顺序),但可以通过一些方法按 key 值进行排序输出。以下是几种常用的实现方式。 使用 so…

    2025年12月14日
    000
  • python中如何实现列表与字典的相互转换?

    列表转字典可通过zip、索引或两两配对实现;2. 字典转列表可提取键、值或键值对;3. 注意键的不可变性和数据完整性。 在Python中,列表和字典是两种不同的数据结构,不能直接一对一转换,但可以根据具体需求进行有规则的相互转换。下面介绍几种常见的转换方式。 1. 列表转字典 将列表转换为字典时,需…

    2025年12月14日
    000
  • python里glob模块怎么用?

    glob模块用于匹配文件路径名,支持通配符如、?、[abc]和*(配合recursive=True实现递归),可快速查找指定模式的文件,返回字符串列表,常用作文件批量处理。 Python 的 glob 模块用于查找符合特定规则的文件路径名,功能类似于正则表达式,但更简单,适合用来匹配文件名模式。 基…

    2025年12月14日
    000
  • python检测给定的路径是否存在的方法

    答案:推荐使用pathlib.Path.exists()检测路径存在。通过os.path.exists()和pathlib.Path.exists()可检查路径是否存在,前者为传统方法,后者自Python 3.4起成为官方推荐,语法更清晰且支持is_file()、is_dir()等细粒度判断,建议新…

    2025年12月14日
    000
  • Python 文件分块读取与写入技巧

    分块读写可避免内存溢出,核心是按固定大小逐步操作文件。使用read(size)和生成器逐块读取,配合’rb’和’wb’模式实现高效复制。处理文本时需注意行完整性,可缓存断行部分。该方法适用于大文件处理、网络传输等场景。 处理大文件时,直接一次性读取或写…

    2025年12月14日
    000
  • Python 将日志内容实时写入文件的方法

    答案:通过重写logging.FileHandler的emit方法并调用flush,可实现日志实时写入。具体做法是创建自定义处理器RealTimeFileHandler,在每次记录后强制刷新缓冲区,确保数据立即写入磁盘;同时建议使用buffering=1的行缓冲模式打开文件,并避免批量写入以保证实时…

    2025年12月14日
    000
  • python pyqt5系统中查找文件

    使用QFileDialog让用户选择文件或目录,结合os.walk和fnmatch实现按条件搜索文件,支持单文件、多文件及目录选择,可集成通配符匹配与glob模块进行高效查找。 在 Python PyQt5 系统中查找文件,通常是指通过图形界面让用户选择文件或目录,或者程序自动搜索指定路径下的文件。…

    2025年12月14日
    000
  • Python finally 子句的执行时机

    finally子句在try块开始执行后无论是否发生异常都会运行,即使遇到return、break等也会在跳转前执行,适合用于释放资源等必须操作。 在 Python 中,finally 子句主要用于确保某些代码无论是否发生异常都会被执行。理解它的执行时机对编写健壮的程序很重要。 finally 的基本…

    2025年12月14日
    000
  • python如何访问列表元素?

    Python中访问列表元素主要通过索引、切片和遍历实现。2. 索引从0开始,正数索引取元素如list[0]为第一个,负数索引如list[-1]为最后一个。3. 切片list[start:end:step]可获取子列表,如my_list[1:4]得[2,3,4]。4. 遍历用for循环逐个访问元素,配…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信