0

0

Python配置文件怎么读_ini yaml解析方案

舞夢輝影

舞夢輝影

发布时间:2026-03-03 20:29:03

|

444人浏览过

|

来源于php中文网

原创

python读取ini和yaml配置文件应选对模块、注意编码与结构差异:ini用configparser(显式指定utf-8编码),yaml用pyyaml的safe_load();统一封装configloader类,按后缀自动解析,支持属性访问与fallback机制。

python配置文件怎么读_ini yaml解析方案

Python读取配置文件iniyaml 是两种最常用格式,选对模块、注意编码和结构差异,就能避免90%的解析问题。

读取 .ini 文件:用 configparser 标准库就够了

无需额外安装,Python 自带,适合简单键值+节(section)结构。

  • 默认不支持注释和嵌套,但能处理 [section] 下的 key = value 形式
  • 推荐显式指定 encoding='utf-8',尤其 Windows 下中文容易乱码
  • 读取后是类字典对象,用 config['section']['key']config.get('section', 'key') 获取值
  • 若需类型自动转换(如布尔、整数),可用 config.getboolean()config.getint() 等方法

读取 .yaml 文件:推荐 PyYAML,注意安全加载

pip install pyyaml</font>,支持复杂数据结构(列表、嵌套字典),但默认加载有风险。</p><div class="aritcle_card flexRow">
                                                        <div class="artcardd flexRow">
                                                                <a class="aritcle_card_img" href="/ai/2077" title="Tana"><img
                                                                                src="https://img.php.cn/upload/ai_manual/000/000/000/175680265491072.png" alt="Tana"  onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
                                                                <div class="aritcle_card_info flexColumn">
                                                                        <a href="/ai/2077" title="Tana">Tana</a>
                                                                        <p>“节点式”AI智能笔记工具,支持超级标签。</p>
                                                                </div>
                                                                <a href="/ai/2077" title="Tana" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
                                                        </div>
                                                </div>
<ul>
  <li>永远用 <code>yaml.safe_load()
,不用 yaml.load() —— 后者可能执行任意代码
  • YAML 对缩进敏感,空格不能混用 Tab;布尔值写 true/falseyes/no(小写)
  • 中文内容建议用双引号包裹,避免解析失败:name: "张三"
  • 读取结果是原生 Python 类型(dict/list/str/int/bool/None),可直接使用
  • 统一管理建议:封装一个 ConfigLoader 类

    把不同格式的加载逻辑收拢,对外提供一致接口,方便后续扩展(比如加环境变量覆盖、热重载)。

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

    • 根据文件后缀自动选择解析器:.ini → configparser.yml/.yaml → PyYAML
    • 支持传入 base_dir 指定配置路径,避免硬编码绝对路径
    • 可加入 fallback 机制:先读 config.yaml,缺失字段再从 config.ini 补充
    • 返回对象可支持属性访问(如 cfg.db.host),用 types.SimpleNamespace 或第三方库如 box

    常见坑与绕过方式

    实际项目中高频出错点,提前避雷。

    • INI 中 key 含空格或特殊字符:configparser 默认只认字母数字和下划线,改用 configparser.ExtendedInterpolation() 或换 YAML
    • YAML 时间/日期被转成 datetime 对象:PyYAML 默认解析 2023-01-01datetime.date,如不需要,用自定义 Loader 禁用时间解析
    • 配置项值为空字符串或 None:YAML 写 value: 表示 null,INI 写 value= 表示空字符串,语义不同,读取后需做空值判断
    • 多环境配置分离:推荐 YAML 的 --- 分段 + 自定义加载逻辑,或用 config_dev.yaml/config_prod.yaml 文件名区分

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    pip安装使用方法
    pip安装使用方法

    安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

    373

    2023.10.09

    更新pip版本
    更新pip版本

    更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

    431

    2024.12.20

    pip设置清华源
    pip设置清华源

    设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

    793

    2024.12.23

    python升级pip
    python升级pip

    本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

    369

    2025.07.23

    c语言中null和NULL的区别
    c语言中null和NULL的区别

    c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

    251

    2023.09.22

    java中null的用法
    java中null的用法

    在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

    988

    2024.03.01

    js 字符串转数组
    js 字符串转数组

    js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

    678

    2023.08.03

    js截取字符串的方法
    js截取字符串的方法

    js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

    219

    2023.09.04

    Swift iOS架构设计与MVVM模式实战
    Swift iOS架构设计与MVVM模式实战

    本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

    3

    2026.03.03

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    最新Python教程 从入门到精通
    最新Python教程 从入门到精通

    共4课时 | 22.5万人学习

    Django 教程
    Django 教程

    共28课时 | 4.7万人学习

    SciPy 教程
    SciPy 教程

    共10课时 | 1.8万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号