Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

pyyaml-erb

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

pyyaml-erb

Used to parse environment variables in the yaml configuration file

  • 1.0.6
  • Source
  • PyPI
  • Socket score

Maintainers
1

pyyaml-erb

解析 yaml 配置文件中的的环境变量


运行环境

介绍

模仿 Ruby 的 ERB 能力,把 yaml 配置文件中的环境变量做简单解析。

安装说明

执行脚本:

python -m pip install --upgrade pip
python -m pip install pyyaml-erb

使用说明

在代码中引入 pyyaml-erb 包,读取配置 yml 配置文件即可:

import erb.yml as yaml
with open(SETTING_PATH, 'r', encoding='utf-8') as file :
    settings = yaml.load(file.read())

配置示例可参考 settings.yml,使用教程可参考单元测试 test_yaml_erb.py

例如环境变量为 JAVA_HOME,只需要在 yaml 配置为 <%= ENV["KEY"] %><%= ${KEY} %> 的值表达式即可识别并解析。

一般而言,值表达式有以下几种配置模式:

  • key_1: <%= ENV["VAR_1"] %>: 默认的使用方式
  • key_2: <%= ENV["VAR_2"] or None %>: 跟默认方式一样,多了默认值为 None,没意义
  • key_3: <%= ENV["VAR_3"] || null %>: 跟默认方式一样,多了默认值为 None,没意义
  • key_4: <%= ENV["VAR_4"] || "nil" %>: 跟默认方式一样,多了默认值为 None,没意义
  • key_5: <%= ENV["VAR_5"] || default %>: 若环境变量不存在,会设置为默认值
  • key_6: "<%= ENV['VAR_6'] or 'default' %>": 若环境变量不存在,会设置为默认值
  • key_7: <%= ENV["VAR_7"] || 7 %>: 若环境变量不存在,会设置为默认值,且默认值会解析为整型
  • key_8: <%= ENV["VAR_8"] || 1.23 %>: 若环境变量不存在,会设置为默认值,且默认值会解析为浮点型
  • key_9: <%= ENV["VAR_9"] || true %>: 若环境变量不存在,会设置为默认值,且默认值会解析为布尔型
  • key_10: <%= ENV["VAR_10"] || 'False' %>: 若环境变量不存在,会设置为默认值,且默认值会解析为布尔型
  • key_0: '<%= ENV["VAR_0"] || ${VAR_11} or default %>': 混合模式

引号用双引号或单引号都可以,值表达式外围用不用引号包围都可以,表达式之间用 ||or 都可以

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc