Uzyskuję dostęp do zmiennej środowiskowej w skrypcie przy użyciu os.environ.get
i następuje rzucenie KeyError
. Nie powoduje to błędu w pytaniu Pythona. Działa na OS X 10.11.6 i jest Python 2.7.10.Python os.environ zgłasza błąd klucza?
Co się dzieje?
$ python score.py
Traceback (most recent call last):
File "score.py", line 4, in <module>
setup_logging()
File "/score/log.py", line 29, in setup_logging
config = get_config()
File "/score/log.py", line 11, in get_config
environment = os.environ.get('NODE_ENV')
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/UserDict.py", line 23, in __getitem__
raise KeyError(key)
KeyError: 'NODE_ENV'
$ python -c "import os; os.environ.get('NODE_ENV')"
$
Zgodnie z wnioskiem, oto kod źródłowy score.py
from __future__ import print_function
from log import get_logger, setup_logging
setup_logging()
log = get_logger('score')
A oto log.py
import json
import os
import sys
from iron_worker import IronWorker
from logbook import Logger, Processor, NestedSetup, StderrHandler, SyslogHandler
IRON_IO_TASK_ID = IronWorker.task_id()
def get_config():
environment = os.environ.get('NODE_ENV')
if environment == 'production':
filename = '../config/config-production.json'
elif environment == 'integration':
filename = '../config/config-integration.json'
else:
filename = '../config/config-dev.json'
with open(filename) as f:
return json.load(f)
def setup_logging():
# This defines a remote Syslog handler
# This will include the TASK ID, if defined
app_name = 'scoreworker'
if IRON_IO_TASK_ID:
app_name += '-' + IRON_IO_TASK_ID
config = get_config()
default_log_handler = NestedSetup([
StderrHandler(),
SyslogHandler(
app_name,
address = (config['host'], config['port']),
level = 'ERROR',
bubble = True
)
])
default_log_handler.push_application()
def get_logger(name):
return Logger(name)
Czy możesz podać kod dla 'score.py'? – wheaties
Nie można odtworzyć ... – Bakuriu
To dziwne. 'get' nie powinien nigdy rzucać' KeyError'; powinien zwracać 'None', jeśli klucz nie zostanie znaleziony (lub dowolne domyślne ustawienie pod warunkiem, że je podasz). Heck, [kod źródłowy] (https://hg.python.org/cpython/file/2.7/Lib/UserDict.py#l91) dla tej metody nie powinien nawet mieć 'raise KeyError (key)' w tym w ogóle! – user2357112