Macintosh中的Python文本到语音

2024-06-01 00:42:05 发布

您现在位置:Python中文网/ 问答频道 /正文

Python中是否有使用Mac Lion内置的文本到语音引擎进行文本到语音转换的库? 我做过谷歌,但大多数都是基于windows的。我试过派特克斯。 我试着跑

import pyttsx
engine = pyttsx.init()
engine.say('Sally sells seashells by the seashore.')
engine.say('The quick brown fox jumped over the lazy dog.')
engine.runAndWait()

但我有这些错误

File "/Users/manabchetia/Documents/Codes/Speech.py", line 2, in <module>
    engine = pyttsx.init()
  File "/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/pyttsx-1.0.egg/pyttsx/__init__.py", line 39, in init
    eng = Engine(driverName, debug)
  File "/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/pyttsx-1.0.egg/pyttsx/engine.py", line 45, in __init__
    self.proxy = driver.DriverProxy(weakref.proxy(self), driverName, debug)
  File "/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/pyttsx-1.0.egg/pyttsx/driver.py", line 64, in __init__
    self._module = __import__(name, globals(), locals(), [driverName])
  File "/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/pyttsx-1.0.egg/pyttsx/drivers/nsss.py", line 18, in <module>
ImportError: No module named Foundation

如何解决这些错误?


Tags: inpyinitlibpackageslinelibrarysite
3条回答

这样做不是简单得多吗?

from os import system
system('say Hello world!')

您可以输入man say来查看使用say命令可以执行的其他操作。

然而,如果您想要一些更高级的特性,导入AppKit也是一种可能,尽管需要一些Cocoa/Objective C知识。

from AppKit import NSSpeechSynthesizer
speechSynthesizer = NSSpeechSynthesizer.alloc().initWithVoice_("com.apple.speech.synthesis.voice.Bruce")
speechSynthesizer.startSpeakingString_('Hi! Nice to meet you!')

如果您想了解更多关于NSSpeechSynthesizer的信息,请查看苹果的文档:https://developer.apple.com/library/mac/#documentation/Cocoa/Reference/ApplicationKit/Classes/NSSpeechSynthesizer_Class/Reference/Reference.html

如果你的目标是MacOSX作为你的平台——PyObjC和NSSpeechSynthesizer是你最好的选择。

下面是一个简单的例子

#!/usr/bin/env python

from  AppKit import NSSpeechSynthesizer
import time
import sys


if len(sys.argv) < 2:
   text = raw_input('type text to speak> ')
else:
   text = sys.argv[1]

nssp = NSSpeechSynthesizer

ve = nssp.alloc().init()

for voice in nssp.availableVoices():
   ve.setVoice_(voice)
   print voice
   ve.startSpeakingString_(text)

   while not ve.isSpeaking():
      time.sleep(0.1)

   while ve.isSpeaking():
      time.sleep(0.1)

请注意,AppKit模块是PyObjC桥的一部分,应该已经安装在您的Mac上了。如果您使用的是操作系统提供的python(/usr/bin/python),则无需安装它

这可能有效:

import subprocess
subprocess.call(["say","Hello World! (MESSAGE)"])

相关问题 更多 >