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

Python项目中添加环境配置文件

在Python项目中添加配置文件有多种方式,每种方式对应不同的依赖包和读取方法。以下是 7种主流配置管理方案,包含安装命令、配置示例和变量读取方法:


1. .env 文件(推荐简单项目)

依赖包: python-dotenv

pip install python-dotenv

.env 文件内容:

DEBUG=true
API_KEY=your_key
DB_HOST=localhost

读取方式:

from dotenv import load_dotenv
import osload_dotenv()  # 默认加载当前目录下的.env文件debug_mode = os.getenv("DEBUG")  # 返回字符串
db_host = os.getenv("DB_HOST", "127.0.0.1")  # 带默认值

2. JSON/YAML 配置文件

依赖包: 无需安装(标准库)或 pyyaml

pip install pyyaml  # 仅YAML需要

config.json:

{"database": {"host": "localhost","port": 5432}
}

读取方式:

import jsonwith open('config.json') as f:config = json.load(f)db_host = config["database"]["host"]

3. INI 格式(传统Windows风格)

依赖包: 标准库 configparser
config.ini:

[database]
host = localhost
port = 5432

读取方式:

from configparser import ConfigParserconfig = ConfigParser()
config.read('config.ini')db_port = config.getint('database', 'port')  # 自动转换类型

4. TOML 格式(Python生态新宠)

依赖包: tomltomli

pip install toml

config.toml:

[database]
host = "localhost"
ports = [8000, 8001]

读取方式:

import tomlwith open("config.toml", "r") as f:config = toml.load(f)ports = config["database"]["ports"]

5. 环境变量直接管理(生产环境推荐)

无需配置文件,直接在系统或容器中设置变量:

# Linux/Mac
export DB_HOST=localhost# Windows
set DB_HOST=localhost

读取方式:

import osdb_host = os.environ["DB_HOST"]  # 直接读取系统变量

6. Pydantic 配置模型(类型安全推荐)

依赖包: pydantic + python-dotenv

pip install pydantic python-dotenv

.env 文件:

DB_HOST=localhost

读取方式:

from pydantic import BaseSettingsclass Settings(BaseSettings):db_host: strdb_port: int = 5432  # 默认值class Config:env_file = ".env"settings = Settings()
print(settings.db_host)  # 自动类型转换

7. 动态热加载配置(高级场景)

依赖包: watchdog + pyyaml

pip install watchdog pyyaml

config.yaml:

app:refresh_interval: 60

动态监听文件变化:

from watchdog.observers import Observer
from watchdog.events import FileSystemEventHandler
import yamlclass ConfigHandler(FileSystemEventHandler):def on_modified(self, event):if event.src_path.endswith('config.yaml'):with open(event.src_path) as f:global configconfig = yaml.safe_load(f)observer = Observer()
observer.schedule(ConfigHandler(), path='.')
observer.start()

方案对比总结

方案适合场景类型安全动态更新复杂度
.env简单项目/开发环境
JSON/YAML结构化配置⭐⭐
INI传统Windows应用
TOML现代Python项目⭐⭐
环境变量生产环境/容器化
Pydantic需要类型验证的项目⭐⭐
动态加载需要运行时修改配置⭐⭐⭐

最佳实践选择

  1. 开发环境.env + python-dotenv
  2. 生产环境:环境变量 + Pydantic验证
  3. 复杂配置:TOML/YAML + Pydantic模型
  4. 动态需求:Watchdog监听 + YAML

💡 安全提示:敏感信息(如密码/API密钥)永远不要提交到版本库,应通过环境变量或密钥管理服务传递。

相关文章:

  • 【Elasticsearch】映射:Join 类型、Flattened 类型、多表关联设计
  • Python 函数全攻略:函数进阶(生成器、闭包、内置函数、装饰器、推导式)
  • 柯尼卡美能达Konica Minolta bizhub 205i打印机信息
  • 《机器学习》(周志华)第一章 绪论
  • 使用Python和Scikit-Learn实现机器学习模型调优
  • 机器学习-经典分类模型
  • 计算机视觉——相机标定
  • 深入解析HarmonyOS5 UIAbility组件:从核心架构到实战应用
  • CRMEB 中 PHP 快递查询扩展实现:涵盖一号通、阿里云、腾讯云
  • pcie 日常问答0604
  • Spring Cloud 多机部署与负载均衡实战详解
  • 【storage】
  • Android开发 系统签名jks制作和问题汇总
  • python 第二章
  • 浅说跟单软件的原理
  • python如何统计图片的颜色分布
  • GenSpark vs Manus实测对比:文献综述与学术PPT,哪家强?
  • Mysql-定时删除数据库中的验证码
  • ADB识别手机系统弹授权框-如何处理多重弹框叠加和重叠问题
  • C++11 Token Bucket (令牌桶)算法的锁无实现及应用
  • 网站的成功案例/seo代理计费系统
  • 电商网站建设报价单/软文推广经典案例
  • 政府部门网站建设简讯/seo渠道是什么意思
  • 嘉兴网站制作/杭州seo薪资水平
  • 如何制作wap网站/优惠活动推广文案
  • 做一个电商网站多少钱/高质量内容的重要性