mirror of
https://github.com/rany2/edge-tts
synced 2024-11-22 01:45:02 +00:00
6355b32f0c
* Add sync versions of stream and save methods In order to provide synchronous interface to the library * Fix save_sync() failing to use metadata_fname and fix typing issues Signed-off-by: rany <ranygh@riseup.net> --------- Signed-off-by: rany <ranygh@riseup.net> Co-authored-by: rany <ranygh@riseup.net>
28 lines
629 B
Python
28 lines
629 B
Python
#!/usr/bin/env python3
|
|
|
|
"""
|
|
Basic audio streaming example for sync interface
|
|
|
|
"""
|
|
|
|
import edge_tts
|
|
|
|
TEXT = "Hello World!"
|
|
VOICE = "en-GB-SoniaNeural"
|
|
OUTPUT_FILE = "test.mp3"
|
|
|
|
|
|
def main() -> None:
|
|
"""Main function to process audio and metadata synchronously."""
|
|
communicate = edge_tts.Communicate(TEXT, VOICE)
|
|
with open(OUTPUT_FILE, "wb") as file:
|
|
for chunk in communicate.stream_sync():
|
|
if chunk["type"] == "audio":
|
|
file.write(chunk["data"])
|
|
elif chunk["type"] == "WordBoundary":
|
|
print(f"WordBoundary: {chunk}")
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|