当前位置: 首页>>代码示例>>Python>>正文


Python Dialog.add_cue方法代码示例

本文整理汇总了Python中dialog.Dialog.add_cue方法的典型用法代码示例。如果您正苦于以下问题:Python Dialog.add_cue方法的具体用法?Python Dialog.add_cue怎么用?Python Dialog.add_cue使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在dialog.Dialog的用法示例。


在下文中一共展示了Dialog.add_cue方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。

示例1: DialogParser

# 需要导入模块: from dialog import Dialog [as 别名]
# 或者: from dialog.Dialog import add_cue [as 别名]
class DialogParser():
    """This class takes care of parsing a chuck of text to make it into a simple list of lines"""
    text = ""

    def __init__(self, webclient, **kwargs):
        """Constructor"""
        self.webclient = webclient
        if "filepath" in kwargs:
            self.load_text_file(kwargs["filepath"])

    def load_text_file(self, filepath):
        with open(os.path.abspath(filepath), mode = "r+") as text_file:
            self.text = unicode(text_file.read(), "utf-8")

    def parse_dialog(self):
        """Parses a dialog using the text class attribute"""

        #attempt to match a header containing voice assignments
        match_obj = re.compile(r'\[(.*?)\](.*)', re.UNICODE | re.DOTALL).match(self.text)

        self.dialog = Dialog()
        if match_obj is None:
            #match didn't work, there's no voice assignment header
            lines = re.compile(r'[\n]+', re.UNICODE).split(self.text)


            for line in lines:
                if line != "":
                    splitted = line.split(":", 1)
                    self.dialog.add_cue(Cue(voice_ref=self.webclient.get_voice_object_from_name(splitted[0]), line=splitted[1]))
        else:
            #match worked,  we have to parse the voice header which looks like this [ character1 : voicename1, ...]
            voice_defs = match_obj.groups()[0].split(",")
            character_dict = dict()
            for voice_def in voice_defs:
                character, voice = tuple([string.strip() for string in voice_def.split(":")])
                character_dict[character.upper()] = self.webclient.get_voice_object_from_name(voice)

            #then parsing the dialog using both the defined characters and the regular voices
            #match didn't work, there's no voice assignment header
            lines = re.compile(r'[\n]+', re.UNICODE).split(match_obj.groups()[1])

            for line in lines:
                if line != "":
                    splitted = line.split(":", 1)
                    #checking if the voice is a "character" voice or a regular voice
                    if character_dict.has_key(splitted[0].strip().upper()):
                        voice_obj = character_dict[splitted[0].strip().upper()]
                    else:
                        voice_obj = self.webclient.get_voice_object_from_name(splitted[0])

                    self.dialog.add_cue(Cue(voice_ref=voice_obj, line=splitted[1]))


    def parse_from_string(self, text):
        self.text = text
        self.parse_dialog()
        return self.dialog
开发者ID:hadware,项目名称:voxpopuli-web,代码行数:60,代码来源:parser.py


注:本文中的dialog.Dialog.add_cue方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。