کتابخانه تبدیل متن به گفتار فارسی با پشتیبانی از چندین شخصیت صوتی
Project description
PersianTTS
یک کتابخانه فارسی برای تبدیل متن به صدا با شخصیتهای مختلف.
این کتابخانه به شما امکان میدهد متن فارسی را با صدای شخصیتهای متفاوت به فایل صوتی تبدیل کنید و آن را ذخیره نمایید.
نصب
برای نصب کتابخانه، ابتدا اطمینان حاصل کنید که Python 3.8 یا بالاتر دارید و سپس از pip استفاده کنید:
لیست شخصیتها (Voices)
| کلید شخصیت | نام شخصیت |
|---|---|
| woman1 | 🌼 شیوا |
| woman2 | 🌷 مهتاب |
| woman3 | 🌺 نگار |
| woman4 | 🌹 ریما |
| man1 | 🌠 راد |
| man2 | 🌠 پیام |
| man3 | 🚀 بهمن |
| man4 | 🚀 برنا |
| man5 | 🚀 برنا-1 |
| man6 | 🦁 کیان |
| man7 | 💧 نیما |
| man8 | ⚡️ آریا |
| boy1 | 🌟 آرش |
from py_persian_tts import PersianTTS, list_voices
import asyncio
async def main():
tts = PersianTTS(default_voice="man1")
# نمایش شخصیتها
print("شخصیتها:", list_voices())
# تبدیل متن به صدا (نسخه async)
await tts.speak_async("سلام این یک تست است.", voice="man2", filename="tewst.wav")
print("عملیات با موفقیت انجام شد")
# اجرای تابع async
if __name__ == "__main__":
asyncio.run(main())
import asyncio
from py_persian_tts import PersianTTS
async def main():
tts = PersianTTS(default_voice="man1", rate_limit=0.5) # هر 2 ثانیه یک درخواست
texts = [
"سلام این یک تست است",
"این هم متن دوم برای تست صف TTS.",
]
tasks = []
for i, text in enumerate(texts):
filename = f"tts_queue_{i+1}.wav"
# اضافه کردن هر متن به صف و گرفتن Future
tasks.append(tts.speak_async(text, filename=filename))
# اجرای همه و گرفتن مسیر فایلها
results = await asyncio.gather(*tasks)
for path in results:
print("فایل صوتی ذخیره شد:", path)
# پایان کار و توقف پردازش صف
await tts.shutdown()
# اجرای مثال
asyncio.run(main())
⚠️ هشدار مهم درباره کلاس TextToSpeech
کلاس TextToSpeech در این کتابخانه با استفاده از Selenium پیادهسازی شده است و برای کارکرد صحیح نیاز دارد:
- Google Chrome نصب شده باشد.
- ChromeDriver مناسب با نسخه کروم روی سیستم شما موجود باشد.
🔹 ChromeDriver چیست؟
ChromeDriver یک برنامهی کمکی است که به Selenium اجازه میدهد با مرورگر Google Chrome تعامل کند.
به عبارت دیگر، Selenium خودش مرورگر را اجرا نمیکند؛ ChromeDriver رابط بین کد پایتون شما و مرورگر کروم است.
بدون ChromeDriver، کلاس TextToSpeech نمیتواند سایت fa.text-to-speech.online را کنترل کرده و فایل صوتی تولید کند.
🔹 نکات مهم:
- اگر ChromeDriver یا گوگل کروم نصب نباشد، هنگام فراخوانی کلاس
TextToSpeechبا خطا مواجه میشوید. - توصیه میشود از WebDriver Manager برای مدیریت خودکار ChromeDriver استفاده کنید تا نسخه مناسب به صورت خودکار دانلود شود.
- مسیر پیشفرض دانلود فایلهای صوتی، پوشهی
downloadsدر مسیر پروژه است. - این روش نیاز به اینترنت دارد، زیرا متن به وبسایت TTS ارسال میشود.
🔹 نصب ChromeDriver
- ابتدا مطمئن شوید Google Chrome روی سیستم شما نصب است.
- نسخه مرورگر خود را بررسی کنید (مثلاً Chrome → Help → About Google Chrome).
- ChromeDriver مناسب همان نسخه را از لینک زیر دانلود کنید:
https://chromedriver.chromium.org/downloads - فایل ChromeDriver دانلود شده را در مسیر PATH سیستم یا یک مسیر دلخواه قرار دهید.
- حالا کلاس
TextToSpeechبدون مشکل کار خواهد کرد.
🔹 مثال استفاده از کلاس
from py_persian_tts import TextToSpeech
tts = TextToSpeech()
file_path = tts.speak("سلام دنیا", gender="male")
tts.close()
ChatVoice - دستیار صوتی فارسی با هوش مصنوعی
یک کلاس برای تبدیل متن به ویس وپاسخ آن به صورت صورت است که میتونید به طور چت ویس باهاش حرف بزنید وفقط به صورت فارسی فقظ پاسخ میده
ویژگیها
- گرفتن پاسخ کوتاه و محاورهای از هوش مصنوعی (Liara AI)
- تبدیل خودکار پاسخ به ویس فارسی
- ذخیره خودکار فایل صوتی با نام امن و قابل شناسایی
- انتخاب صدای شخصیتها (woman1، man1، boy1، و غیره)
- پاسخها کوتاه و مناسب خواندن با صدا (حداکثر 2–3 جمله)
مثال کلاس ChatVoice
from py_persian_tts import ChatVoice
# ساخت کلاس با API key و صدای مورد نظر
chat = ChatVoice(
api_key="کلید_تو_اینجا",
voice="woman2"
)
# پرسش و دریافت فایل صوتی
audio_file = chat.ask("سلام خودتو معرفی کن؟")
print("فایل صوتی ساخته شد:", audio_file)
نصب
pip install --upgrade py-persian-tts
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file py_persian_tts-2.1.0.tar.gz.
File metadata
- Download URL: py_persian_tts-2.1.0.tar.gz
- Upload date:
- Size: 11.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d80669ba55ea9f72c42f5b457a8f80151811381e4e1749ef1d6d6107060cea03
|
|
| MD5 |
e327b1ca8e03dfc743e278eba84d07ca
|
|
| BLAKE2b-256 |
35e4a2b92837fd12aa335f450a442b1eff908ce557a0f8fdcfc4ef3be59ce619
|
File details
Details for the file py_persian_tts-2.1.0-py3-none-any.whl.
File metadata
- Download URL: py_persian_tts-2.1.0-py3-none-any.whl
- Upload date:
- Size: 10.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0e3ac257c410ac3d2c73c726fec82237b0aaa0b702d313d8e4835090c1349e77
|
|
| MD5 |
12eb4d3d21dfb0ad1b8af395dc70ae76
|
|
| BLAKE2b-256 |
b1507f6f64d7001a7a4379d7ba2a1ee534dade21748e7fe3ddb7f185facadb90
|