Я попытался загрузить свой код Python (торговый бот Binance) на Heroku, но произошла ошибка. Может ли кто-нибудь помочь мне, пожалуйста?
from binance.client import Client
from datetime import datetime
client = Client(api,key)
symbol = 'IOSTUSDT'
for i in client.futures_historical_klines(symbol, Client.KLINE_INTERVAL_1MINUTE, '2022-03-16'):
print(i)
Ошибка
2022-03-16T13:37:45.890497+00:00 app[worker.1]: Traceback (most recent call last):
2022-03-16T13:37:45.890552+00:00 app[worker.1]: File "/app/code.py", line 14, in <module>
2022-03-16T13:37:45.890743+00:00 app[worker.1]: for i in client.futures_historical_klines(symbol, Client.KLINE_INTERVAL_1MINUTE, '2022-03-16'):
2022-03-16T13:37:45.890758+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.9/site-packages/binance/client.py", line 5709, in futures_historical_klines
2022-03-16T13:37:45.892661+00:00 app[worker.1]: return self._historical_klines(symbol, interval, start_str, end_str=end_str, limit=limit, klines_type=HistoricalKlinesType.FUTURES)
---here too much text--
2022-03-16T13:37:45.894613+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.9/site-packages/dateparser/languages/locale.py", line 131, in translate
2022-03-16T13:37:45.894755+00:00 app[worker.1]: relative_translations = self._get_relative_translations(settings=settings)
2022-03-16T13:37:45.894769+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.9/site-packages/dateparser/languages/locale.py", line 158, in _get_relative_translations
2022-03-16T13:37:45.894912+00:00 app[worker.1]: self._generate_relative_translations(normalize=True))
2022-03-16T13:37:45.894927+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.9/site-packages/dateparser/languages/locale.py", line 172, in _generate_relative_translations
2022-03-16T13:37:45.895085+00:00 app[worker.1]: pattern = DIGIT_GROUP_PATTERN.sub(r'?P<n>\d+', pattern)
2022-03-16T13:37:45.895100+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.9/site-packages/regex/regex.py", line 700, in _compile_replacement_helper
2022-03-16T13:37:45.895586+00:00 app[worker.1]: is_group, items = _compile_replacement(source, pattern, is_unicode)
2022-03-16T13:37:45.895600+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.9/site-packages/regex/_regex_core.py", line 1736, in _compile_replacement
2022-03-16T13:37:45.896352+00:00 app[worker.1]: raise error("bad escape \\%s" % ch, source.string, source.pos)
2022-03-16T13:37:45.896430+00:00 app[worker.1]: regex._regex_core.error: bad escape \d at position 7
У меня была такая же проблема - библиотека регулярных выражений была обновлена с 2022.3.2 до 2022.3.15. Вы можете установить версию в требованиях, пока проблема не будет исправлена в следующей версии.
Сегодня у меня началась точно такая же проблема. Как упомянула Ольга, это стало происходить после выхода версии 2022.3.15 библиотеки регулярных выражений.
Я исследовал основную причину, проверив стек вызовов, и увидел, что библиотека dateparser
использует регулярное выражение для анализа строк даты и времени.
Я попытался запустить только фрагмент кода ниже, он также дал мне ту же ошибку. Поэтому я смог локализовать ошибку.
dateparser.parse('1 Jan, 2020', settings = {'TIMEZONE': "UTC"})
Что вы можете сделать, так это просто удалить библиотеку регулярных выражений и установить более старую версию. Вы также можете добавить версию в свой файл requirements.txt.
pip uninstall regex -y
pip install regex==2022.3.2
Подробные версии регулярного выражения библиотека.
Теперь есть новая версия для dateparser==1.1.1
, который отвечает за обновление пакета regex
. Обновление до последней версии dateparser
решило проблему для меня.
Можете дать ссылки на ваш источник информации?