tetos


Nametetos JSON
Version 0.4.2 PyPI version JSON
download
home_pageNone
SummaryUnified interface for multiple Text-to-Speech (TTS) providers
upload_time2025-01-08 09:52:44
maintainerNone
docs_urlNone
authorNone
requires_python>=3.8
licenseApache-2.0
keywords tts text-to-speech speech audio ai nlp
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # TeToS
<!--index start-->

[![PyPI](https://img.shields.io/pypi/v/tetos)](https://pypi.org/project/tetos/)
[![Python](https://img.shields.io/pypi/pyversions/tetos)](https://pypi.org/project/tetos/)
[![License](https://img.shields.io/pypi/l/tetos)](https://www.apache.org/licenses/LICENSE-2.0)
[![Downloads](https://pepy.tech/badge/tetos)](https://pepy.tech/project/tetos)
[![Documentation Status](https://readthedocs.org/projects/tetos/badge/?version=latest)](https://tetos.readthedocs.io/latest/?badge=latest)

A unified interface for multiple Text-to-Speech (TTS) providers.


## Supported TTS providers

| Provider                                                                                             | Requirements                                                                                                                                                                                                                                                      |
| ---------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| [Edge-TTS](https://github.com/rany2/edge-tts)                                                        | -                                                                                                                                                                                                                                                                 |
| [OpenAI TTS](https://platform.openai.com/docs/guides/text-to-speech)                                 | `api_key`: OpenAI API key                                                                                                                                                                                                                                         |
| [Azure TTS](https://docs.microsoft.com/en-us/azure/cognitive-services/speech-service/text-to-speech) | `speech_key`: Azure Speech service key<br>`speech_region`: Azure Speech service region                                                                                                                                                                            |
| [Google TTS](https://cloud.google.com/text-to-speech?hl=zh-CN)                                       | [Enable the Text-to-Speech API in the Google Cloud Console](https://console.developers.google.com/apis/api/texttospeech.googleapis.com/overview?project=586547753837)<br>Set env var `GOOGLE_APPLICATION_CREDENTIALS` as the path to the service account key file |
| [Volcengine TTS(火山引擎)](https://console.volcengine.com/sami)                                      | `access_key`: Volcengine access key ID. ([Get it here](https://console.volcengine.com/iam/keymanage/))<br>`secret_key`: Volcengine access secret key. ([Get it here](https://console.volcengine.com/iam/keymanage/))<br>`app_key`: Volcengine app key             |
| [Baidu TTS](https://ai.baidu.com/tech/speech/tts)                                                    | `api_key`: Baidu API key<br>`secret_key`: Baidu secret key<br>Both can be acquired at the [console](https://console.bce.baidu.com/ai/#/ai/speech/app/list)                                                                                                        |
| [Minimax TTS](https://www.minimaxi.com/document/speech-synthesis-engine?id=645e034eeb82db92fba9ac20) | `api_key`: Minimax API key<br>`group_id`: Minimax group ID<br>Both can be acquired at the [Minimax console](https://www.minimaxi.com/user-center/basic-information)                                                                                               |
| [迅飞 TTS](https://www.xfyun.cn/services/online_tts)                                                 | `app_id`: Xunfei APP ID<br>`api_key`: Xunfei API key<br>`api_secret`: Xunfei API secret                                                                                                                                                                           |
| [Fish Audio](https://fish.audio)                                                                     | `api_key`: Fish Audio API key                                                                                                                                                                                                                                     |

## Installation

Tetos requires Python 3.8 or higher.

```bash
pip install tetos
```

## CLI Usage

```
tetos PROVIDER [PROVIDER_OPTIONS] TEXT [--output FILE]
```

Please run `tetos --help` for available providers and options.

Examples

```
tetos google "Hello, world!"
tetos azure "Hello, world!" --output output.mp3   # save to another file
tetos edge --lang zh-CN "你好,世界!"  # specify language
tetos openai --voice echo "Hello, world!"  # specify voice
```

## API Usage

Use Azure TTS as an example:

```python
from tetos.azure import AzureSpeaker

speaker = AzureSpeaker(speech_key='...', speech_region='...')
speaker.say('Hello, world!', 'output.mp3')
```

The initialization parameters may be different for other providers.

## Work behind a proxy

TeTos respects the proxy environment variables `HTTP_PROXY`, `HTTPS_PROXY`, `ALL_PROXY` and `NO_PROXY`.

## TODO

- [x] Google TTS
- [ ] SSML support

## License

[Apache License 2.0](https://www.apache.org/licenses/LICENSE-2.0)

<!--index end-->

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "tetos",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": null,
    "keywords": "tts, text-to-speech, speech, audio, ai, nlp",
    "author": null,
    "author_email": "Frost Ming <me@frostming.com>",
    "download_url": "https://files.pythonhosted.org/packages/8f/86/f1bbb2d528937ae825c2108c8debe02e7cd7bcc3a2ab089b79f1496c6053/tetos-0.4.2.tar.gz",
    "platform": null,
    "description": "# TeToS\n<!--index start-->\n\n[![PyPI](https://img.shields.io/pypi/v/tetos)](https://pypi.org/project/tetos/)\n[![Python](https://img.shields.io/pypi/pyversions/tetos)](https://pypi.org/project/tetos/)\n[![License](https://img.shields.io/pypi/l/tetos)](https://www.apache.org/licenses/LICENSE-2.0)\n[![Downloads](https://pepy.tech/badge/tetos)](https://pepy.tech/project/tetos)\n[![Documentation Status](https://readthedocs.org/projects/tetos/badge/?version=latest)](https://tetos.readthedocs.io/latest/?badge=latest)\n\nA unified interface for multiple Text-to-Speech (TTS) providers.\n\n\n## Supported TTS providers\n\n| Provider                                                                                             | Requirements                                                                                                                                                                                                                                                      |\n| ---------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |\n| [Edge-TTS](https://github.com/rany2/edge-tts)                                                        | -                                                                                                                                                                                                                                                                 |\n| [OpenAI TTS](https://platform.openai.com/docs/guides/text-to-speech)                                 | `api_key`: OpenAI API key                                                                                                                                                                                                                                         |\n| [Azure TTS](https://docs.microsoft.com/en-us/azure/cognitive-services/speech-service/text-to-speech) | `speech_key`: Azure Speech service key<br>`speech_region`: Azure Speech service region                                                                                                                                                                            |\n| [Google TTS](https://cloud.google.com/text-to-speech?hl=zh-CN)                                       | [Enable the Text-to-Speech API in the Google Cloud Console](https://console.developers.google.com/apis/api/texttospeech.googleapis.com/overview?project=586547753837)<br>Set env var `GOOGLE_APPLICATION_CREDENTIALS` as the path to the service account key file |\n| [Volcengine TTS(\u706b\u5c71\u5f15\u64ce)](https://console.volcengine.com/sami)                                      | `access_key`: Volcengine access key ID. ([Get it here](https://console.volcengine.com/iam/keymanage/))<br>`secret_key`: Volcengine access secret key. ([Get it here](https://console.volcengine.com/iam/keymanage/))<br>`app_key`: Volcengine app key             |\n| [Baidu TTS](https://ai.baidu.com/tech/speech/tts)                                                    | `api_key`: Baidu API key<br>`secret_key`: Baidu secret key<br>Both can be acquired at the [console](https://console.bce.baidu.com/ai/#/ai/speech/app/list)                                                                                                        |\n| [Minimax TTS](https://www.minimaxi.com/document/speech-synthesis-engine?id=645e034eeb82db92fba9ac20) | `api_key`: Minimax API key<br>`group_id`: Minimax group ID<br>Both can be acquired at the [Minimax console](https://www.minimaxi.com/user-center/basic-information)                                                                                               |\n| [\u8fc5\u98de TTS](https://www.xfyun.cn/services/online_tts)                                                 | `app_id`: Xunfei APP ID<br>`api_key`: Xunfei API key<br>`api_secret`: Xunfei API secret                                                                                                                                                                           |\n| [Fish Audio](https://fish.audio)                                                                     | `api_key`: Fish Audio API key                                                                                                                                                                                                                                     |\n\n## Installation\n\nTetos requires Python 3.8 or higher.\n\n```bash\npip install tetos\n```\n\n## CLI Usage\n\n```\ntetos PROVIDER [PROVIDER_OPTIONS] TEXT [--output FILE]\n```\n\nPlease run `tetos --help` for available providers and options.\n\nExamples\n\n```\ntetos google \"Hello, world!\"\ntetos azure \"Hello, world!\" --output output.mp3   # save to another file\ntetos edge --lang zh-CN \"\u4f60\u597d\uff0c\u4e16\u754c\uff01\"  # specify language\ntetos openai --voice echo \"Hello, world!\"  # specify voice\n```\n\n## API Usage\n\nUse Azure TTS as an example:\n\n```python\nfrom tetos.azure import AzureSpeaker\n\nspeaker = AzureSpeaker(speech_key='...', speech_region='...')\nspeaker.say('Hello, world!', 'output.mp3')\n```\n\nThe initialization parameters may be different for other providers.\n\n## Work behind a proxy\n\nTeTos respects the proxy environment variables `HTTP_PROXY`, `HTTPS_PROXY`, `ALL_PROXY` and `NO_PROXY`.\n\n## TODO\n\n- [x] Google TTS\n- [ ] SSML support\n\n## License\n\n[Apache License 2.0](https://www.apache.org/licenses/LICENSE-2.0)\n\n<!--index end-->\n",
    "bugtrack_url": null,
    "license": "Apache-2.0",
    "summary": "Unified interface for multiple Text-to-Speech (TTS) providers",
    "version": "0.4.2",
    "project_urls": {
        "Documentation": "https://tetos.readthedocs.io/latest/",
        "Repository": "https://github.com/frostming/tetos"
    },
    "split_keywords": [
        "tts",
        " text-to-speech",
        " speech",
        " audio",
        " ai",
        " nlp"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "4521bcfb13ca88188eb25f78dbf86cab0a2e2773881b68e08c2d2abce463da92",
                "md5": "223f85dd8336ad4f5aa0277f7c48db54",
                "sha256": "d0c54479ac98b0a3dc6cc30b99f1f806dba7db7449714e8de29a011e3c94057a"
            },
            "downloads": -1,
            "filename": "tetos-0.4.2-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "223f85dd8336ad4f5aa0277f7c48db54",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 27505,
            "upload_time": "2025-01-08T09:52:42",
            "upload_time_iso_8601": "2025-01-08T09:52:42.505625Z",
            "url": "https://files.pythonhosted.org/packages/45/21/bcfb13ca88188eb25f78dbf86cab0a2e2773881b68e08c2d2abce463da92/tetos-0.4.2-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "8f86f1bbb2d528937ae825c2108c8debe02e7cd7bcc3a2ab089b79f1496c6053",
                "md5": "4e4df19ea9fb887668717f791b354f25",
                "sha256": "680aa553cda237280d5c2dace1ee4ee76dcbc83d1c0839f8c07499b0ce161543"
            },
            "downloads": -1,
            "filename": "tetos-0.4.2.tar.gz",
            "has_sig": false,
            "md5_digest": "4e4df19ea9fb887668717f791b354f25",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 23487,
            "upload_time": "2025-01-08T09:52:44",
            "upload_time_iso_8601": "2025-01-08T09:52:44.657348Z",
            "url": "https://files.pythonhosted.org/packages/8f/86/f1bbb2d528937ae825c2108c8debe02e7cd7bcc3a2ab089b79f1496c6053/tetos-0.4.2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-08 09:52:44",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "frostming",
    "github_project": "tetos",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "tetos"
}
        
Elapsed time: 0.48619s