`pip install prlps-logger`
пример использования:
```python
# указываем путь до файла с логами куда будет все записываться:
from pathlib import Path
log_file = Path(__file__).parent / 'my_logs.log'
# создание экземпляра класса с нужным уровнем логгирования:
logger = GetLog(log_file, 'DEBUG')
# уровень логгирования можно не указывать, тогда по умолчанию будет 'WARN':
# logger = Logger(log_file)
logger.warn('текст')
logger.error('текст')
logger.info('текст')
logger.crit('текст')
logger.event('текст')
try:
my_iq = ((0 + 0) * 0) ** 0 / 0
except Exception as e:
# тут твоя какая-то обработка исключения...
logger.error(f'ты больной?\n{e}') # логгирование
# посмотрим как логгируются не обработанные исключения:
# my_iq = ((0 + 0) * 0) ** 0 / 0
# лог (только созданный этим логгером) можно передать в виде html для удобного просмотра или вывода куда-то, например на страницу через fastapi и т.п.
html_log = logger.log_to_html() # создаст html текущего лога, аналогично вызову logger.log_to_html(log_file)
# или создать html с указанием пути до конкретного лог-файла, не обязательно текущего
# html_log = logger.log_to_html(log_file) # для текущего лога
# html_log = logger.log_to_html('/path/to/file.log.3') # для какого-то другого лог-файла, например после ротации логов
# метод возвращает код html, можно записать в файл или вернуть как HTMLResponse:
print(html_log)
```
Raw data
{
"_id": null,
"home_page": "https://github.com/gniloyprolaps/prlps_logger",
"name": "prlps-logger",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.6",
"maintainer_email": null,
"keywords": null,
"author": "prolapser",
"author_email": null,
"download_url": "https://files.pythonhosted.org/packages/3d/70/b75a3ea86d1553413e1f52ecb14c5362d1712059ce901938ceb8c603317c/prlps_logger-0.0.2.tar.gz",
"platform": null,
"description": " `pip install prlps-logger`\n\n\u043f\u0440\u0438\u043c\u0435\u0440 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f:\n\n```python\n# \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u043c \u043f\u0443\u0442\u044c \u0434\u043e \u0444\u0430\u0439\u043b\u0430 \u0441 \u043b\u043e\u0433\u0430\u043c\u0438 \u043a\u0443\u0434\u0430 \u0431\u0443\u0434\u0435\u0442 \u0432\u0441\u0435 \u0437\u0430\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c\u0441\u044f:\nfrom pathlib import Path\nlog_file = Path(__file__).parent / 'my_logs.log'\n\n# \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0430 \u043a\u043b\u0430\u0441\u0441\u0430 \u0441 \u043d\u0443\u0436\u043d\u044b\u043c \u0443\u0440\u043e\u0432\u043d\u0435\u043c \u043b\u043e\u0433\u0433\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f:\nlogger = GetLog(log_file, 'DEBUG')\n# \u0443\u0440\u043e\u0432\u0435\u043d\u044c \u043b\u043e\u0433\u0433\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u043c\u043e\u0436\u043d\u043e \u043d\u0435 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c, \u0442\u043e\u0433\u0434\u0430 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u0431\u0443\u0434\u0435\u0442 'WARN':\n# logger = Logger(log_file)\n\nlogger.warn('\u0442\u0435\u043a\u0441\u0442')\nlogger.error('\u0442\u0435\u043a\u0441\u0442')\nlogger.info('\u0442\u0435\u043a\u0441\u0442')\nlogger.crit('\u0442\u0435\u043a\u0441\u0442')\nlogger.event('\u0442\u0435\u043a\u0441\u0442')\n\ntry:\n my_iq = ((0 + 0) * 0) ** 0 / 0\nexcept Exception as e:\n # \u0442\u0443\u0442 \u0442\u0432\u043e\u044f \u043a\u0430\u043a\u0430\u044f-\u0442\u043e \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f...\n logger.error(f'\u0442\u044b \u0431\u043e\u043b\u044c\u043d\u043e\u0439?\\n{e}') # \u043b\u043e\u0433\u0433\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435\n\n# \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043a\u0430\u043a \u043b\u043e\u0433\u0433\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u043d\u0435 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0430\u043d\u043d\u044b\u0435 \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f:\n# my_iq = ((0 + 0) * 0) ** 0 / 0\n\n# \u043b\u043e\u0433 (\u0442\u043e\u043b\u044c\u043a\u043e \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0439 \u044d\u0442\u0438\u043c \u043b\u043e\u0433\u0433\u0435\u0440\u043e\u043c) \u043c\u043e\u0436\u043d\u043e \u043f\u0435\u0440\u0435\u0434\u0430\u0442\u044c \u0432 \u0432\u0438\u0434\u0435 html \u0434\u043b\u044f \u0443\u0434\u043e\u0431\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440\u0430 \u0438\u043b\u0438 \u0432\u044b\u0432\u043e\u0434\u0430 \u043a\u0443\u0434\u0430-\u0442\u043e, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 \u0447\u0435\u0440\u0435\u0437 fastapi \u0438 \u0442.\u043f.\nhtml_log = logger.log_to_html() # \u0441\u043e\u0437\u0434\u0430\u0441\u0442 html \u0442\u0435\u043a\u0443\u0449\u0435\u0433\u043e \u043b\u043e\u0433\u0430, \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e \u0432\u044b\u0437\u043e\u0432\u0443 logger.log_to_html(log_file)\n# \u0438\u043b\u0438 \u0441\u043e\u0437\u0434\u0430\u0442\u044c html \u0441 \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u0435\u043c \u043f\u0443\u0442\u0438 \u0434\u043e \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u043b\u043e\u0433-\u0444\u0430\u0439\u043b\u0430, \u043d\u0435 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u0442\u0435\u043a\u0443\u0449\u0435\u0433\u043e\n# html_log = logger.log_to_html(log_file) # \u0434\u043b\u044f \u0442\u0435\u043a\u0443\u0449\u0435\u0433\u043e \u043b\u043e\u0433\u0430\n# html_log = logger.log_to_html('/path/to/file.log.3') # \u0434\u043b\u044f \u043a\u0430\u043a\u043e\u0433\u043e-\u0442\u043e \u0434\u0440\u0443\u0433\u043e\u0433\u043e \u043b\u043e\u0433-\u0444\u0430\u0439\u043b\u0430, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u043f\u043e\u0441\u043b\u0435 \u0440\u043e\u0442\u0430\u0446\u0438\u0438 \u043b\u043e\u0433\u043e\u0432\n# \u043c\u0435\u0442\u043e\u0434 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u043a\u043e\u0434 html, \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0432 \u0444\u0430\u0439\u043b \u0438\u043b\u0438 \u0432\u0435\u0440\u043d\u0443\u0442\u044c \u043a\u0430\u043a HTMLResponse:\nprint(html_log)\n```\n",
"bugtrack_url": null,
"license": "LICENSE.txt",
"summary": "\u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u043f\u0440\u0438\u043c\u0435\u0440 \u043b\u043e\u0433\u0433\u0435\u0440\u0430 \u0434\u043b\u044f \u0437\u0430\u043f\u0438\u0441\u0438 \u043b\u043e\u0433\u043e\u0432 \u0432 \u0444\u0430\u0439\u043b \u0438 \u0432\u044b\u0432\u043e\u0434\u0430 \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u044c, \u0438\u043b\u0438 \u0432 html \u0434\u043b\u044f HTMLResponse FastAPI",
"version": "0.0.2",
"project_urls": {
"Homepage": "https://github.com/gniloyprolaps/prlps_logger"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "4f3a36ade45e6cc39ed92cae9c621f2680e038b7327f8273f7567ed254c37dd2",
"md5": "719ceac79e4fb0116d8ba14aa4c03cde",
"sha256": "6fd39b2a9948c38917c219ba2c8130aed26f113403aa0373a7531aa6f37dad38"
},
"downloads": -1,
"filename": "prlps_logger-0.0.2-py3-none-any.whl",
"has_sig": false,
"md5_digest": "719ceac79e4fb0116d8ba14aa4c03cde",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.6",
"size": 5282,
"upload_time": "2025-01-20T14:37:33",
"upload_time_iso_8601": "2025-01-20T14:37:33.500588Z",
"url": "https://files.pythonhosted.org/packages/4f/3a/36ade45e6cc39ed92cae9c621f2680e038b7327f8273f7567ed254c37dd2/prlps_logger-0.0.2-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "3d70b75a3ea86d1553413e1f52ecb14c5362d1712059ce901938ceb8c603317c",
"md5": "eda7961b857229439e7141ccf55d61b4",
"sha256": "fc9fddd4f863554d78e574e03f8a2677fa38797be8ddbd55053df9dc7b094599"
},
"downloads": -1,
"filename": "prlps_logger-0.0.2.tar.gz",
"has_sig": false,
"md5_digest": "eda7961b857229439e7141ccf55d61b4",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.6",
"size": 5032,
"upload_time": "2025-01-20T14:37:34",
"upload_time_iso_8601": "2025-01-20T14:37:34.523055Z",
"url": "https://files.pythonhosted.org/packages/3d/70/b75a3ea86d1553413e1f52ecb14c5362d1712059ce901938ceb8c603317c/prlps_logger-0.0.2.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-20 14:37:34",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "gniloyprolaps",
"github_project": "prlps_logger",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "prlps-logger"
}