При попытке перенести приложение Django в Heroku я получил следующую ошибку: TomlDecodeError("Неверная дата или номер")
Когда я git push
мое приложение Django для Heroku, я получаю ошибку ниже. Как мне узнать, что нужно изменить в моем коде из-за этой ошибки? Я не уверен, какую информацию о дате я неправильно настроил, чтобы вызвать эту ошибку. Если бы вы могли указать мне правильное направление, это было бы здорово! В моих настройках Pipfile.lock написано python 3.6.4, когда я использую python 3.6.3. Может ли это быть проблема? Есть ли способ обновить Python без переустановки всех моих вещей?
remote: File "/tmp/build_913f5397888fc6f8943894f7ab01ea65/.heroku/python/lib/python3.6/site-packages/pipenv/vendor/toml.py", line 454, in _load_line
remote: raise TomlDecodeError("Invalid date or number")
remote: toml.TomlDecodeError: Invalid date or number
remote: ! Push rejected, failed to compile Python app.
Вот полная ошибка трассировки ниже:
:\Users\Jup\Drop>git push heroku master
Counting objects: 19, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (15/15), done.
Writing objects: 100% (19/19), 8.93 KiB | 0 bytes/s, done.
Total 19 (delta 8), reused 0 (delta 0)
remote: Compressing source files... done.
remote: Building source:
remote:
remote: -----> Python app detected
remote: ! The latest version of Python 3 is python-3.6.4 (you are using python-3.6.3, which is unsupported).
remote: ! We recommend upgrading by specifying the latest version (python-3.6.4).
remote: Learn More: https://devcenter.heroku.com/articles/python-runtimes
remote: -----> Installing requirements with latest Pipenv…
remote: Traceback (most recent call last):
remote: File "/app/.heroku/python/lib/python3.6/site-packages/pipenv/project.py", line 272, in parsed_pipfile
remote: return contoml.loads(contents)
remote: File "/tmp/build_913f5397888fc6f8943894f7ab01ea65/.heroku/python/lib/python3.6/site-packages/pipenv/patched/contoml/__init__.py", line 15, in loa
ds
remote: elements = parse_tokens(tokens)
remote: File "/tmp/build_913f5397888fc6f8943894f7ab01ea65/.heroku/python/lib/python3.6/site-packages/pipenv/patched/prettytoml/parser/__init__.py", line
17, in parse_tokens
remote: return _parse_token_stream(TokenStream(tokens))
remote: File "/tmp/build_913f5397888fc6f8943894f7ab01ea65/.heroku/python/lib/python3.6/site-packages/pipenv/patched/prettytoml/parser/__init__.py", line
32, in _parse_token_stream
remote: raise ParsingError('Failed to parse line {}'.format(pending.head.row))
remote: prettytoml.parser.errors.ParsingError: Failed to parse line 15
remote:
remote: During handling of the above exception, another exception occurred:
remote:
remote: Traceback (most recent call last):
remote: File "/app/.heroku/python/bin/pipenv", line 11, in <module>
remote: sys.exit(cli())
remote: File "/tmp/build_913f5397888fc6f8943894f7ab01ea65/.heroku/python/lib/python3.6/site-packages/pipenv/vendor/click/core.py", line 722, in __call__
remote: return self.main(*args, **kwargs)
remote: File "/tmp/build_913f5397888fc6f8943894f7ab01ea65/.heroku/python/lib/python3.6/site-packages/pipenv/vendor/click/core.py", line 697, in main
remote: rv = self.invoke(ctx)
remote: File "/tmp/build_913f5397888fc6f8943894f7ab01ea65/.heroku/python/lib/python3.6/site-packages/pipenv/vendor/click/core.py", line 1066, in invoke
remote: return _process_result(sub_ctx.command.invoke(sub_ctx))
remote: File "/tmp/build_913f5397888fc6f8943894f7ab01ea65/.heroku/python/lib/python3.6/site-packages/pipenv/vendor/click/core.py", line 895, in invoke
remote: return ctx.invoke(self.callback, **ctx.params)
remote: File "/tmp/build_913f5397888fc6f8943894f7ab01ea65/.heroku/python/lib/python3.6/site-packages/pipenv/vendor/click/core.py", line 535, in invoke
remote: return callback(*args, **kwargs)
remote: File "/app/.heroku/python/lib/python3.6/site-packages/pipenv/cli.py", line 1775, in install
remote: pre = project.settings.get('allow_prereleases')
remote: File "/app/.heroku/python/lib/python3.6/site-packages/pipenv/project.py", line 293, in settings
remote: return self.parsed_pipfile.get('pipenv', {})
remote: File "/app/.heroku/python/lib/python3.6/site-packages/pipenv/project.py", line 274, in parsed_pipfile
remote: return toml.loads(contents)
remote: File "/tmp/build_913f5397888fc6f8943894f7ab01ea65/.heroku/python/lib/python3.6/site-packages/pipenv/vendor/toml.py", line 373, in loads
remote: multibackslash)
remote: File "/tmp/build_913f5397888fc6f8943894f7ab01ea65/.heroku/python/lib/python3.6/site-packages/pipenv/vendor/toml.py", line 454, in _load_line
remote: raise TomlDecodeError("Invalid date or number")
remote: toml.TomlDecodeError: Invalid date or number
remote: ! Push rejected, failed to compile Python app.
remote:
remote: ! Push failed
remote: Verifying deploy...
remote:
remote: ! Push rejected to shrouded-ocean-19461.
remote:
To https://git.heroku.com/shrouded-ocean-19461.git
! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'https://git.heroku.com/shrouded-ocean-19461.git'
Ошибка может быть в моем Pipfile
, Может быть проблема в неправильном номере версии?
[[source]]
url = "https://pypi.python.org/simple"
verify_ssl = true
name = "pypi"
[requires]
python_version = "3.6"
[packages]
amqp==2.2.2
anyjson==0.3.3
apache-libcloud==2.2.1
arrow==0.12.0
beautifulsoup4==4.6.0
billiard==3.5.0.3
blessed==1.14.2
bs4==0.0.1
celery==4.1.0
certifi==2017.7.27.1
chardet==3.0.4
click==6.7
cx-Freeze==6.0b1
dj-database-url==0.4.2
Django==2.0
django-celery==3.2.2
django-celery-beat==1.1.0
django-celery-results==1.0.1
django-heroku==0.2.0
django-picklefield==1.0.0
django-q==0.8.1
django-redis-cache==1.7.1
enum-compat==0.0.2
eventlet==0.21.0
flake8==3.5.0
greenlet==0.4.12
gunicorn==19.7.1
idna==2.6
itsdangerous==0.24
Jinja2==2.10
kombu==4.1.0
MarkupSafe==1.0
mccabe==0.6.1
mtgsdk==1.3.1
numpy==1.13.3
olefile==0.44
pandas==0.21.0
pew==1.1.1
Pillow==4.3.0
pipenv==9.0.0
psutil==5.3.1
psycopg2==2.7.3.2
pycodestyle==2.3.1
pycurl==7.43.0.1
pyflakes==1.6.0
python-dateutil==2.6.1
pytz==2017.3
redis==2.10.6
requests==2.18.4
selenium==3.7.0
six==1.11.0
urllib3==1.22
vine==1.1.4
virtualenv==15.1.0
virtualenv-clone==0.2.6
wcwidth==0.1.7
Werkzeug==0.12.2
whitenoise==3.3.1
[dev-packages]
2 ответа
Произошла та же ошибка, меняя все пакеты в Pipfile с примером из Django==2.0
в Django = "==2.0"
работал на меня.
Примечание: у меня не было Pipfile.lock
Проблема была с моими настройками Pipfile.lock. Он имеет другой формат при замене require.text. Я изменил форматирование так:
Django==2.0
к
Django = "==2.0"
Но это вызвало другую ошибку, например:
Your Pipfile.lock (af8c37) is out of date. Expected: (3ca3d5)
Я должен выяснить, как это исправить сейчас. Пожалуйста, дайте мне знать, если у вас есть идеи. Спасибо