prlps-logger


Nameprlps-logger JSON
Version 0.0.2 PyPI version JSON
download
home_pagehttps://github.com/gniloyprolaps/prlps_logger
Summaryпростой пример логгера для записи логов в файл и вывода в консоль, или в html для HTMLResponse FastAPI
upload_time2025-01-20 14:37:34
maintainerNone
docs_urlNone
authorprolapser
requires_python>=3.6
licenseLICENSE.txt
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
             `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"
}
        
Elapsed time: 0.44885s