Metadata-Version: 2.1
Name: youcomsum
Version: 0.0.1
Summary: Batch summarize YouTube video comments using artificial intelligence (OpenAI, ...).
Home-page: https://github.com/Dashstrom/youcomsum
License: MIT
Keywords: python
Author: Dashstrom
Author-email: dashstrom.pro@gmail.com
Maintainer: Dashstrom
Maintainer-email: dashstrom.pro@gmail.com
Requires-Python: >=3.9,<3.14
Classifier: Development Status :: 3 - Alpha
Classifier: Environment :: Console
Classifier: Framework :: Pytest
Classifier: Framework :: Sphinx
Classifier: Framework :: tox
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: System Administrators
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: English
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Typing :: Typed
Provides-Extra: cov
Provides-Extra: docs
Provides-Extra: format
Provides-Extra: lint
Provides-Extra: tasks
Provides-Extra: test
Requires-Dist: commitizen (==4.1.1) ; extra == "tasks"
Requires-Dist: coverage[toml] (==7.6.10) ; extra == "cov"
Requires-Dist: mypy (==1.14.1) ; extra == "lint" or extra == "format"
Requires-Dist: openai
Requires-Dist: poethepoet (==0.32.2) ; extra == "tasks"
Requires-Dist: pre-commit (==4.1.0) ; extra == "tasks"
Requires-Dist: pre-commit-hooks (==5.0.0) ; extra == "tasks"
Requires-Dist: pycountry (>=24.6.1,<25.0.0)
Requires-Dist: pytest (==8.3.4) ; extra == "test" or extra == "cov" or extra == "lint" or extra == "format"
Requires-Dist: pytest-cov (==6.0.0) ; extra == "cov"
Requires-Dist: pytest-mock (==3.14.0) ; extra == "test" or extra == "cov" or extra == "lint" or extra == "format"
Requires-Dist: ruff (==0.9.4) ; extra == "lint" or extra == "format"
Requires-Dist: sphinx (==7.4.7) ; extra == "docs"
Requires-Dist: sphinx-rtd-theme (==3.0.2) ; extra == "docs"
Requires-Dist: sphinxcontrib-mermaid (==1.0.0) ; extra == "docs"
Requires-Dist: torch (>=2.6.0,<3.0.0)
Requires-Dist: transformers (>=4.50.0,<5.0.0)
Requires-Dist: types-tqdm (==4.67.0.20241221) ; extra == "lint" or extra == "format"
Requires-Dist: typing-extensions (>=4.8.0)
Requires-Dist: youtube-comment-downloader
Project-URL: Documentation, https://dashstrom.github.io/youcomsum
Project-URL: Repository, https://github.com/Dashstrom/youcomsum
Description-Content-Type: text/x-rst

.. role:: bash(code)
  :language: bash

*********
youcomsum
*********

|ci-docs| |ci-lint| |ci-tests| |pypi| |versions| |license|

.. |ci-docs| image:: https://github.com/Dashstrom/youcomsum/actions/workflows/docs.yml/badge.svg
  :target: https://github.com/Dashstrom/youcomsum/actions/workflows/docs.yml
  :alt: CI : Docs

.. |ci-lint| image:: https://github.com/Dashstrom/youcomsum/actions/workflows/lint.yml/badge.svg
  :target: https://github.com/Dashstrom/youcomsum/actions/workflows/lint.yml
  :alt: CI : Lint

.. |ci-tests| image:: https://github.com/Dashstrom/youcomsum/actions/workflows/tests.yml/badge.svg
  :target: https://github.com/Dashstrom/youcomsum/actions/workflows/tests.yml
  :alt: CI : Tests

.. |pypi| image:: https://img.shields.io/pypi/v/youcomsum.svg
  :target: https://pypi.org/project/youcomsum
  :alt: PyPI : youcomsum

.. |versions| image:: https://img.shields.io/pypi/pyversions/youcomsum.svg
  :target: https://pypi.org/project/youcomsum
  :alt: Python : versions

.. |license| image:: https://img.shields.io/badge/license-MIT-green.svg
  :target: https://github.com/Dashstrom/youcomsum/blob/main/LICENSE
  :alt: License : MIT

Description
###########

Batch summarize YouTube video comments using artificial intelligence (OpenAI, ...).

Documentation
#############

Documentation is available on https://dashstrom.github.io/youcomsum

Installation
############

You can install :bash:`youcomsum` using `uv <https://docs.astral.sh/uv/getting-started/installation/>`_
from `PyPI <https://pypi.org/project>`_

..  code-block:: bash

  pip install uv
  uv tool install youcomsum

Usage
#####

Before use :bash:`youcomsum`, you must set your :bash:`OPENAI_API_KEY` following the `Best Practices for API Key Safety <https://help.openai.com/en/articles/5112595-best-practices-for-api-key-safety>`_.

..  code-block:: bash

  youcomsum -v 'http://youtu.be/dQw4w9WgXcQ'

Usage as module
###############

..  code-block:: python

  from youcomsum import YouComSum

  youcomsum = YouComSum()
  text: str = youcomsum.summarize("http://youtu.be/dQw4w9WgXcQ")
  print(text)

Development
###########

Contributing
************

Contributions are very welcome. Tests can be run with :bash:`poe check`, please
ensure the coverage at least stays the same before you submit a pull request.

Setup
*****

You need to install `Poetry <https://python-poetry.org/docs/#installation>`_
and `Git <https://git-scm.com/book/en/v2/Getting-Started-Installing-Git>`_
for work with this project.

..  code-block:: bash

  git clone https://github.com/Dashstrom/youcomsum
  cd youcomsum
  poetry install --all-extras
  poetry run poe setup
  poetry shell

Poe
********

Poe is available for help you to run tasks.

..  code-block:: text

  test           Run test suite.
  lint           Run linters: ruff checker and ruff formatter and mypy.
  format         Run linters in fix mode.
  check          Run all checks: lint, test and docs.
  check-tag      Check if the current tag match the version.
  cov            Run coverage for generate report and html.
  open-cov       Open html coverage report in webbrowser.
  docs           Build documentation.
  open-docs      Open documentation in webbrowser.
  setup          Setup pre-commit.
  pre-commit     Run pre-commit.
  commit         Test, commit and push.
  clean          Clean cache files.

Skip commit verification
************************

If the linting is not successful, you can't commit.
For forcing the commit you can use the next command :

..  code-block:: bash

  git commit --no-verify -m 'MESSAGE'

Commit with commitizen
**********************

To respect commit conventions, this repository uses
`Commitizen <https://github.com/commitizen-tools/commitizen?tab=readme-ov-file>`_.

..  code-block:: bash

  cz c

How to add dependency
*********************

..  code-block:: bash

  poetry add 'PACKAGE'

Ignore illegitimate warnings
****************************

To ignore illegitimate warnings you can add :

- **# noqa: ERROR_CODE** on the same line for ruff.
- **# type: ignore[ERROR_CODE]** on the same line for mypy.
- **# pragma: no cover** on the same line to ignore line for coverage.
- **# doctest: +SKIP** on the same line for doctest.

Uninstall
#########

..  code-block:: bash

  pipx uninstall youcomsum

License
#######

This work is licensed under `MIT <https://github.com/Dashstrom/youcomsum/blob/main/LICENSE>`_.

