Невозможно импортировать шесть в локальной среде разработки GAE - PullRequest
0 голосов
/ 18 декабря 2018

Я получил ошибку ниже при попытке запустить мое приложение GAE Python 2.7.

ImportError: No module named six

Я проследил эту страницу и настроил мой файл app.yaml, как показано ниже.

...
libraries:
  - name: six
    version: "1.9.0"
  - name: flask
    version:  "0.12"
  - name: jinja2
    version: "2.6"
  - name: pycrypto
    version: "2.6.1"
  - name: markupsafe
    version: "0.23"
  - name: werkzeug
    version: "0.11.10"
  - name: pytz
    version: "2017.3"

Впервые я получил эту ошибку при попытке импортировать пакет flask.Поэтому я написал некоторый отладочный код для изучения этой проблемы и обнаружил, что не могу импортировать six напрямую.

Я распечатал переменную sys.path.

['C:\\Users\\user\\PycharmProjects\\gaeapp\\dist', 'C:\\Users\\user\\PycharmProjects\\gaeapp\\dist\\lib', 'C:\\Program Files (x86)\\Google\\google_appengine', 'C:\\Program Files (x86)\\Google\\google_appengine', 'C:\\Users\\user\\AppData\\Local\\conda\\conda\\envs\\py27-base\\DLLs', 'C:\\Users\\user\\AppData\\Local\\conda\\conda\\envs\\py27-base\\lib', 'C:\\Users\\user\\AppData\\Local\\conda\\conda\\envs\\py27-base', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\flask-0.12', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\jinja2-2.6', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\pycrypto-2.6.1', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\markupsafe-0.23', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\werkzeug-0.11.10', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\pytz-2017.3', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\six-1.9.0', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\click-6.6', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\itsdangerous-0.24', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\setuptools-0.6c11', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\protorpc-1.0', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\webapp2-2.3', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\webob-1.1.1', 'C:\\Program Files (x86)\\Google\\google_appengine\\lib\\yaml-3.10']

Я также проверил C: \ Program Files (x86) \ Google \ google_appengine \ lib \ six-1.9.0 .

Я также пытался импортировать пакет six непосредственно в оболочку pythonи это удалось.

(py27-base) C:\>set PYTHONPATH=C:\Program Files (x86)\Google\google_appengine\lib\six-1.9.0

(py27-base) C:\>python
Python 2.7.15 |Anaconda, Inc.| (default, Nov 13 2018, 17:33:26) [MSC v.1500 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> import six
>>> six
<module 'six' from 'C:\Program Files (x86)\Google\google_appengine\lib\six-1.9.0\six\__init__.py'>
>>> exit()

Поэтому мне интересно, что помешало моему приложению импортировать six в среде dev_appserver .

Сведения о среде

  • Windows 10 64 бит, сборка 1809
  • Python 2.7.15 :: Anaconda, Inc.
  • GAE Python Standard SDK, версия 1.9.80. Not GCloud SDK

Сведения о журнале

2018-12-19 14:00:18 Running command: "['C:\\Users\\user\\AppData\\Local\\conda\\conda\\envs\\py27-base\\pythonw.exe', 'C:\\Program Files (x86)\\Google\\google_appengine\\dev_appserver.py', '--skip_sdk_update_check=yes', '--port=8080', '--admin_port=8000', 'C:\\Users\\user\\PycharmProjects\\gaeapp\\dist']"
INFO     2018-12-19 14:00:22,907 devappserver2.py:278] Skipping SDK update check.
INFO     2018-12-19 14:00:23,483 api_server.py:275] Starting API server at: http://localhost:54700
INFO     2018-12-19 14:00:23,493 dispatcher.py:256] Starting module "default" running at: http://localhost:8080
INFO     2018-12-19 14:00:23,497 admin_server.py:150] Starting admin server at: http://localhost:8000
INFO     2018-12-19 14:00:28,579 instance.py:294] Instance PID: 11908
INFO     2018-12-19 14:00:30,862 module.py:861] default: "GET / HTTP/1.1" 404 -
INFO     2018-12-19 14:00:35,223 module.py:434] [default] Detected file changes:
  blog\__init__.pyc
WARNING  2018-12-19 06:00:35,575 sandbox.py:1086] The module _winreg is whitelisted for local dev only. If your application relies on _winreg, it is likely that it will not function properly in production.

WARNING  2018-12-19 06:00:35,953 sandbox.py:1086] The module _ctypes is whitelisted for local dev only. If your application relies on _ctypes, it is likely that it will not function properly in production.

WARNING  2018-12-19 06:00:36,165 sandbox.py:1086] The module msvcrt is whitelisted for local dev only. If your application relies on msvcrt, it is likely that it will not function properly in production.

ERROR    2018-12-19 06:00:36,315 wsgi.py:263] 

Traceback (most recent call last):

  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\runtime\wsgi.py", line 240, in Handle

handler = _config_handle.add_wsgi_middleware(self._LoadHandler())

  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\runtime\wsgi.py", line 299, in _LoadHandler

handler, path, err = LoadObject(self._handler)

  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\runtime\wsgi.py", line 85, in LoadObject

obj = __import__(path[0])

  File "C:\Users\user\PycharmProjects\gaeapp\dist\blog\__init__.py", line 6, in <module>

from blog.resources import bloglist, blog, comment

  File "C:\Users\user\PycharmProjects\gaeapp\dist\blog\resources\__init__.py", line 7, in <module>

from flask_restful import fields

  File "C:\Users\user\PycharmProjects\gaeapp\dist\lib\flask_restful\fields.py", line 6, in <module>

import six

  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\tools\devappserver2\python\runtime\sandbox.py", line 1149, in load_module

raise ImportError('No module named %s' % fullname)

ImportError: No module named six

INFO     2018-12-19 14:00:36,362 module.py:861] default: "GET /blog/resources/blogs HTTP/1.1" 500 -
INFO     2018-12-19 14:00:41,301 instance.py:294] Instance PID: 19088
INFO     2018-12-19 14:00:41,301 module.py:434] [default] Detected file changes:
  blog

Ответы [ 2 ]

0 голосов
/ 19 декабря 2018

Я создал тестовую среду согласно описанию выше, но не столкнулся с проблемами при импорте модулей, указанных в файле app.yaml.Другим возможным устранением неполадок может быть создание демонстрационного приложения для двойной проверки возможности запуска GAE Launcher из этих встроенных библиотек в среде dev_appserver.Для этого перейдя в панель запуска Google App Engine, File > Add Demo Application > python > guestbook и отредактировав файл app.yaml и guestbook.py, чтобы импортировать (например) модуль six и распечатать var = six.__version__ на странице гостевой книги, высможет проверить, возникает ли исключение.

Возможное решение, предложенное Алексом, состояло бы в том, чтобы напрямую скопировать сторонние библиотеки локально в (под) каталог, добавив их в requirements.txt file, запустив pip install -t lib -r requirements.txt и создав соответствующий appengine_config.py файл, как описано в этой статье .Имейте в виду, однако, что при импорте только библиотек в среду «Разработка» проблема все равно может проявиться в Production, и в этом случае файл appengine_config.py будет иметь вид:

# appengine_config.py
from google.appengine.ext import vendor

# Add any libraries install in the "lib" folder.
vendor.add('lib')

идеально (как видно из статьи, представленной в ответе Алекса).

Я бы также добавил, что если в проекте есть и другие локальные библиотеки (что, похоже, имеет место в результате трассировки), обязательно установите этизависимости внутри вашего приложения, как описано в этом ответе .

0 голосов
/ 19 декабря 2018

У меня возникли проблемы со случайными библиотеками, которые отсутствуют в рабочей среде и отсутствуют на моем локальном хосте (а именно, pycrypto на osx)

Итак, в дополнение к наличию папки lib для всех моих сторонних библиотек: https://cloud.google.com/appengine/docs/standard/python/tools/using-libraries-python-27

Я создал вторую папку с именем localhost_libs для этих проблемных библиотек

, а затем в моем appengine_config.py у меня есть это:

from google.appengine.ext import vendor
vendor.add('lib')

if os.environ.get('SERVER_SOFTWARE', '').startswith('Development'):
    vendor.add('localhost_libs')
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...