アプリケーションのメイン ファイル (または別の場所) でいくつかのモジュール レベルの変数を定義し、必要に応じてそれらをインポートして使用できます。
この方法を使用して、環境変数から SQLAlchemy のデータベース接続文字列などの設定を作成します。
デフォルトでは、モジュールは Python で 1 回だけ解析されるため、モジュール レベルのコードは 1 回だけ実行されます。
更新 1
ピラミッド プロジェクトのディレクトリ構造が次のようになっているとします。
.
├── __init__.py
├── models
│ ├── __init__.py
│ ├── meta
│ │ ├── base.py
│ │ ├── __init__.py
│ │ ├── orm.py
│ │ ├── schema.py
│ │ ├── types.py
│ ├── users.py
├── security.py
├── settings
│ ├── database.py
│ ├── email.py
│ ├── __init__.py
│ ├── redis.py
│ ├── security.py
├── static
│ ├── css
│ │ └── main.css
│ └── js
│ ├── app.js
│ ├── app-services.js
│ ├── controllers
│ │ └── excel_preview.js
├── templates
│ ├── auth
│ │ └── login.html
│ ├── base.html
│ ├── home.html
├── views
│ ├── auth.py
│ ├── home.py
│ ├── __init__.py
のコードに従っているとしましょうsettings/redis.py
:
import os
import redis
def get_redis_client():
# Read settings from environment variables
redis_db_name = os.environ.get('REDIS_NAME')
redis_host = os.environ.get('REDIS_HOST')
redis_port = os.environ['REDIS_PORT']
# create a redis connection
redis_client = redis.StrictRedis(
host=redis_host,
port=redis_port,
db=redis_db_name,
)
# return newly created redis connection
return redis_client
redis_client = get_redis_client()
SOME_SETTING_STORED_IN_REDIS = redis_client.get('some_setting_stored_in_redis')
このSOME_SETTING_STORED_IN_REDIS
変数はどこからでも使用できます。アプリの名前が含まれている場合はexample_app
、次のexample_app/views/home.py
ように使用できます。
from pyramid.view import view_config
from example_app.settings.redis import SOME_SETTING_STORED_IN_REDIS
def includeme(config):
config.add_route('home', '/')
@view_config(
route_name='home',
renderer='home.html',
permission='authenticated'
)
def home_view(request):
return {
"some_setting": SOME_SETTING_STORED_IN_REDIS,
}
あなたは似たようなことを達成しようとしていると思います。