當前位置: 首頁>>代碼示例>>Python>>正文


Python num2words.num2words方法代碼示例

本文整理匯總了Python中num2words.num2words方法的典型用法代碼示例。如果您正苦於以下問題:Python num2words.num2words方法的具體用法?Python num2words.num2words怎麽用?Python num2words.num2words使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在num2words的用法示例。


在下文中一共展示了num2words.num2words方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: word_to_num

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def word_to_num(word):
    """ Replace numbers with their written representation. """
    result = word

    match = float_pattern.search(result)

    while match is not None:
        num_word = num2words.num2words(float(match.group().replace(',', '.')), lang='de').lower()
        before = result[:match.start()]
        after = result[match.end():]
        result = ' '.join([before, num_word, after])
        match = float_pattern.search(result)

    match = int_pattern.search(result)

    while match is not None:
        num_word = num2words.num2words(int(match.group()), lang='de')
        before = result[:match.start()]
        after = result[match.end():]
        result = ' '.join([before, num_word, after])
        match = int_pattern.search(result)

    return result 
開發者ID:AASHISHAG,項目名稱:deepspeech-german,代碼行數:25,代碼來源:text_cleaning.py

示例2: modify_xml

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def modify_xml(xml_name, num):
    if num is not None:
        if num <= 5:
            xml_name = xml_name.replace('.xml', num2words.num2words(num) + '.xml')
            # xml_name = 'mass/' + xml_name
            xml_name = 'strength/' + xml_name
        elif num <= 10:
            num -= 5
            xml_name = xml_name.replace('.xml', num2words.num2words(num) + '.xml')
            xml_name = 'strength/' + xml_name
        elif num <= 15:
            num -= 10
            xml_name = xml_name.replace('.xml', num2words.num2words(num) + '.xml')
            xml_name = 'length/' + xml_name
        else:
            raise NotImplementedError
        # print xml_name
    return xml_name 
開發者ID:WilsonWangTHU,項目名稱:neural_graph_evolution,代碼行數:20,代碼來源:walkers.py

示例3: normalize_name

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def normalize_name(name):
    name = re_ordinal_number.sub(lambda m: num2words(int(m.group(1)), to='ordinal'), name)
    return re_strip_non_chars.sub('', name.lower()) 
開發者ID:EdwardBetts,項目名稱:osm-wikidata,代碼行數:5,代碼來源:match.py

示例4: get_syllable_count_word

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def get_syllable_count_word(self, word):
        """
        Formats and retrieves syllable count for individual words, including
        numerals.

        Words are first checked for in `self.counter`. If not found, SbA is
        performed, and if no syllabification exists, then the naive algorithm is
        performed. The resulting syllable count is then added to `self.counter`.

        :param word: Word to count syllables.
        :type word: str | float
        :return n_syllables: Number of syllables.
        :rtype: int
        """

        # Check if word is numerical
        try:
            word = num2words(float(word)).replace('-', ' ')
            return sum([self.get_syllable_count_word(word) for word in word.split()])
        except ValueError:
            # Else, format word
            word = self.regex.sub('', word).lower()

        # Check if word has already been processed
        if word in self.counter:
            return self.counter[word]

        # Remove apostrophes, do SbA
        n_syllables = self._sba(word.replace("'", ''))

        # If SbA fails, do naive
        if n_syllables is None:
            n_syllables = self._naive(word)

        # Add word to already processed words
        self.counter[word] = n_syllables

        return n_syllables 
開發者ID:SwagLyrics,項目名稱:autosynch,代碼行數:40,代碼來源:syllable_counter.py

示例5: alphabetic_value

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def alphabetic_value(number_entity, language):
    from num2words import num2words

    value = number_entity[RESOLVED_VALUE][VALUE]
    if value != int(value):  # num2words does not handle floats correctly
        return None
    return num2words(int(value), lang=language) 
開發者ID:snipsco,項目名稱:snips-nlu,代碼行數:9,代碼來源:string_variations.py

示例6: get_number_as_words

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def get_number_as_words(number, format=constants.words.Ordinal):
    """Return a textual version of the provided word."""
    return num2words(number, to=format) 
開發者ID:GatorEducator,項目名稱:gatorgrader,代碼行數:5,代碼來源:util.py

示例7: transcribe_digits_fun

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def transcribe_digits_fun(self,words):

    from num2words import num2words
    def is_number(s):
      try:
        int(s)
        return 'int'
      except ValueError:
        pass
      try:
        float(s)
        return 'float'
      except ValueError:
        return False

    words = words.split()
    new_words = []
    mutliple_word_number_found = False
    for word in words:
      if is_number(word):
        transcr = num2words(int(word)).upper().replace(',', '').replace('-', ' ').split()
        if len(transcr)>1:
          mutliple_word_number_found = True
        new_words += transcr
      else:
        new_words.append(word)

    new_words = ' '.join(new_words)

    if not new_words == words:
      print (words + ' ---> ' + new_words)

    return new_words 
開發者ID:afourast,項目名稱:deep_lip_reading,代碼行數:35,代碼來源:label_vectorization.py

示例8: digits2words

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def digits2words(phrase, lang='en'):
  wordified = ''
  for word in phrase.split():
    if word.isnumeric():
      word = num2words(float(word), lang=lang)
    wordified = wordified + word + " "
  return wordified[:-1]


# Replace word-form numbers with digits. 
開發者ID:m0ngr31,項目名稱:kodi-voice,代碼行數:12,代碼來源:kodi.py

示例9: save_xml_files

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def save_xml_files(model_names, xml_number, xml_contents):
    # get the xml path ready
    number_str = num2words.num2words(xml_number)
    xml_names = model_names + number_str[0].upper() + number_str[1:] + '.xml'
    xml_file_path = os.path.join(OUTPUT_BASE_DIR, xml_names)

    # save the xml file
    f = open(xml_file_path, 'w')
    f.write(xml_contents)
    f.close() 
開發者ID:WilsonWangTHU,項目名稱:neural_graph_evolution,代碼行數:12,代碼來源:asset_generator.py

示例10: get_env_num_str

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def get_env_num_str(self, number):
        num_str = num2words.num2words(number)
        return num_str[0].upper() + num_str[1:] 
開發者ID:WilsonWangTHU,項目名稱:neural_graph_evolution,代碼行數:5,代碼來源:centipede_env.py

示例11: n2w_1k

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def n2w_1k(x, use_ordinal=False):
    if x > 1000:
        return ''
    return num2words(x, to='ordinal' if use_ordinal else 'cardinal') 
開發者ID:rowanz,項目名稱:swagaf,代碼行數:6,代碼來源:events.py

示例12: _n2w

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def _n2w(n, to):
    try:
        return num2words(n, lang=to_locale(get_language()), to=to)
    except NotImplementedError:
        # fall back to gettext for these words
        gettext_noop("first")
        gettext_noop("second")
        gettext_noop("third")
        gettext_noop("fourth")
        gettext_noop("fifth")
        return _(num2words(n, lang="en", to=to))

# ------------------------------------------------------------------------------ 
開發者ID:linuxsoftware,項目名稱:ls.joyous,代碼行數:15,代碼來源:manythings.py

示例13: toDaysOffsetStr

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def toDaysOffsetStr(offset):
    retval = ""
    if offset <= -2:
        n = num2words(-offset, lang=to_locale(get_language()), to="cardinal")
        retval = _("{N} days before").format(N=n.capitalize())
    elif offset == -1:
        retval = _("The day before")
    elif offset == 1:
        retval = _("The day after")
    elif offset >= 2:
        n = num2words(offset, lang=to_locale(get_language()), to="cardinal")
        retval = _("{N} days after").format(N=n.capitalize())
    return retval

# ------------------------------------------------------------------------------ 
開發者ID:linuxsoftware,項目名稱:ls.joyous,代碼行數:17,代碼來源:manythings.py

示例14: extract_fuzzy_fit

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def extract_fuzzy_fit(mention_x: MentionDataLight, mention_y: MentionDataLight) -> RelationType:
        """
        Check if input mentions has fuzzy fit relation

        Args:
            mention_x: MentionDataLight
            mention_y: MentionDataLight

        Returns:
            RelationType.FUZZY_FIT or RelationType.NO_RELATION_FOUND
        """
        try:
            from num2words import num2words
        except (AttributeError, ImportError):
            logger.error(
                "num2words is not installed, please install nlp_architect with [all] package. "
                + "for example: pip install nlp_architect[all]"
            )
            sys.exit()

        relation = RelationType.NO_RELATION_FOUND
        mention1_str = mention_x.tokens_str
        mention2_str = mention_y.tokens_str
        if difflib.SequenceMatcher(None, mention1_str, mention2_str).ratio() * 100 >= 90:
            relation = RelationType.FUZZY_FIT
            return relation

        # Convert numbers to words
        x_words = [
            num2words(int(w)).replace("-", " ") if w.isdigit() else w for w in mention1_str.split()
        ]
        y_words = [
            num2words(int(w)).replace("-", " ") if w.isdigit() else w for w in mention2_str.split()
        ]

        fuzzy_result = (
            difflib.SequenceMatcher(None, " ".join(x_words), " ".join(y_words)).ratio() * 100 >= 85
        )
        if fuzzy_result:
            relation = RelationType.FUZZY_FIT
        return relation 
開發者ID:NervanaSystems,項目名稱:nlp-architect,代碼行數:43,代碼來源:computed_relation_extraction.py

示例15: number_to_words

# 需要導入模塊: import num2words [as 別名]
# 或者: from num2words import num2words [as 別名]
def number_to_words(n, locale="en", num_type="cardinal"):
    """
    Convert an integer numeric value into natural language text.

    :param n: Number to convert.
    :type n: int

    :param locale:
        Language to convert to. Currently supported values:
         - "de"
         - "en"
         - "en_gb"
         - "es"
         - "fr"
         - "lt"
    :type locale: str

    :param num_type:
        Type of number. Must be one of the following values:
         - "cardinal"
         - "ordinal"

    :returns: Natural language text.
    :rtype: str

    :raises: TypeError, ValueError
    """
    if not isinstance(n, int):
        raise TypeError("Expected int, got '%s' instead" % type(n))
    if not isinstance(locale, basestring):
        raise TypeError("Expected basestring, got '%s' instead" % type(locale))
    if not isinstance(num_type, basestring):
        raise TypeError("Expected basestring, got '%s' instead" % type(num_type))
    if num_type == "ordinal" and n < 0:
        raise ValueError("Can't get ordinal value from negative number")

    if num_type == "ordinal":
        try:
            return num2words(n, ordinal=True, lang=locale.lower())
        except NotImplementedError:
            raise ValueError("Language or num_type are not valid.")
    elif num_type == "cardinal":
        try:
            return num2words(n, ordinal=False, lang=locale.lower())
        except NotImplementedError:
            raise ValueError("Language or num_type are not valid.")
    else:
        return num2words(n, ordinal=False, lang="en") 
開發者ID:blackye,項目名稱:luscan-devel,代碼行數:50,代碼來源:natural_language.py


注:本文中的num2words.num2words方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。