Categories
Tags
Alamofire Android AppStoreConnect AWS Bun C++ cAdvisor CFW Cloudflare Cloudflare Access Cloudflare KV Cloudflare Tunnel Cloudflare Workers D1 Deno DevContainer Discord Docker ECR ECS Edizon Emulator EmuMMC Fastlane Firestore Frida Ghidra Git GitHub GitHub Actions GitLab GPG Grafana HACGUI Heroku Homebrew Hono IDA Pro iOS IPSwitch Jailbreak Javascript Jotai JSON JWT LanPlay Linode macOS Mirakurun MongoDB NestJS NextJS Nintendo Nintendo Switch NodeJS PHP PostgreSQL Prisma Programming Prometheus Python React Realm RealmSwift Ruby Salmon Run Salmonia3+ Shogi Sideload Snap Splatoon Splatoon2 Splatoon3 SSH Stable Diffusion Starlight Swift Swift Package SwiftUI Switch TensorRT Turf War Typescript TypeScript Ubuntu Ubuntu Server Vite VNC VPN VSCode Vue WARP Wireguard XCode Xcode yarn zsh 家電 横歩取り
475 words
2 minutes
Python
環境構築
Python は 3.3 からvirtualenvを取り込んでvenvとして標準で使えるようになりました。
例えばVENVという名前の仮想環境を作りたいのなら以下のコマンドでいけます。
python -m venv .venv --prompt VENV
VScode だとPythonのプラグインを入れればvenvにも対応して Workspace を開いたタイミングでvenvを有効化してくれます。
VScode で自動読み込み
VScode で Workspace に.venvが含まれる場合は自動で認識して仮想環境を有効化してくれる、とある。
が、やってみると
環境変数
秘匿にしておきたい鍵などはローカル環境では.envに書いておき、サーバで動かす際にはENVIRONMENT VALUEみたいな設定から値を設定することが多いです。
例えば、以下のような環境変数が書けます。
CLIENT_SECRET=1234567890
環境変数は全て文字列として扱われるのでダブルクオーテーションは不要です。
これを読み込むための Python のコードは以下のとおりです。
import os
from dotenv import load_dotenv
load_dotenv()
if __name__=="__main__":
print(os.environ.get('CLIENT_SECRET'))
このコードの意味については以下で解説します。
os.environ
これはシステムの環境変数を読み込むコマンドなので、これだけを使っても.envの中身を読み込むことはできません。なぜなら、.envはあくまでもローカルの環境変数だからです。
よって、.envの中身を一時的にシステムの環境変数に追加する必要があります。
pyhton-dotenv
python-dotenvは.envに書き込まれた内容をシステム環境変数に読み込みます。
よって、os.environとpython-dotenvを組み合わせることで Python で.envのデータを読み込むことができるようになるわけです。