Added Slovene

This commit is contained in:
Blaž Bregar
2017-10-22 18:06:49 +02:00
parent 1176539b62
commit 2ee0e49a8b
3 changed files with 102 additions and 27 deletions

View File

@@ -67,6 +67,7 @@ cardinal one.
* ``no`` (Norwegian) * ``no`` (Norwegian)
* ``pl`` (Polish) * ``pl`` (Polish)
* ``pt_BR`` (Brazilian Portuguese) * ``pt_BR`` (Brazilian Portuguese)
* ``sl`` (Slovene)
* ``ru`` (Russian) * ``ru`` (Russian)
* ``tr`` (Turkish) * ``tr`` (Turkish)
* ``vn`` (Vietnamese) * ``vn`` (Vietnamese)

View File

@@ -37,13 +37,7 @@ class Num2Word_SL(Num2Word_EU):
self.errmsg_toobig = "Number is too large to convert to words." self.errmsg_toobig = "Number is too large to convert to words."
self.exclude_title = [] self.exclude_title = []
lows = ["non", "okt", "sept", "sext", "quint", "quadr", "tr", "b", "m"] self.mid_numwords = [(1000, "tisoč"), (900, "devetsto"), (800, "osemsto"),
units = ["", "un", "duo", "tre", "quattuor", "quin", "sex", "sept",
"okto", "novem"]
tens = ["dez", "vigint", "trigint", "quadragint", "quinquagint",
"sexagint", "septuagint", "oktogint", "nonagint"]
self.high_numwords = ["zent"]+self.gen_high_numwords(units, tens, lows)
self.mid_numwords = [(1000, "tisoč "), (900, "devetsto"), (800, "osemsto"),
(700, "sedemsto"), (600, "šesto"), (500, "petsto"), (400, "štiristo"), (300, "tristo"), (700, "sedemsto"), (600, "šesto"), (500, "petsto"), (400, "štiristo"), (300, "tristo"),
(200, "dvesto"), (100, "sto"), (200, "dvesto"), (100, "sto"),
(90, "devetdeset"), (80, "osemdeset"), (70, "sedemdeset"), (90, "devetdeset"), (80, "osemdeset"), (70, "sedemdeset"),
@@ -52,19 +46,27 @@ class Num2Word_SL(Num2Word_EU):
self.low_numwords = ["dvajset", "devetnajst", "osemnajst", "sedemnajst", self.low_numwords = ["dvajset", "devetnajst", "osemnajst", "sedemnajst",
"šestnajst", "petnajst", "štirinajst", "trinajst", "šestnajst", "petnajst", "štirinajst", "trinajst",
"dvanajst", "enajst", "deset", "devet", "osem", "sedem", "dvanajst", "enajst", "deset", "devet", "osem", "sedem",
"šest", "pet", "štiri", "tri", "dva", "ena", "šest", "pet", "štiri", "tri", "dve", "ena",
"nič"] "nič"]
self.ords = { "ena" : "prvi", self.ords = { "ena" : "prv",
"dve" : "drugi", "dve" : "drug",
"acht" : "ach", "tri" : "tretj",
"sieben" : "sieb", "štiri" : "četrt",
"ig" : "igs" } "sedem" : "sedm",
"osem" : "osm",
"sto" : "stot",
"tisoč" : "tisoč",
"miljon" : "miljont"
}
self.ordflag = False self.ordflag = False
def merge(self, curr, next): def merge(self, curr, next):
ctext, cnum, ntext, nnum = curr + next ctext, cnum, ntext, nnum = curr + next
if ctext == "dve" and not self.ordflag:
ctext = "dva"
if cnum == 1: if cnum == 1:
if nnum < 10**6 or self.ordflag: if nnum < 10**6 or self.ordflag:
return next return next
@@ -72,19 +74,37 @@ class Num2Word_SL(Num2Word_EU):
if nnum > cnum: if nnum > cnum:
if nnum >= 10**6: if nnum >= 10**6:
if cnum > 1: if self.ordflag:
if ntext.endswith("d") or self.ordflag: ntext += "t"
elif cnum == 2:
if ntext.endswith("d"):
ntext += "i"
else:
ntext += "a"
elif 2 < cnum < 5:
if ntext.endswith("d"):
ntext += "e"
elif not ntext.endswith("d"):
ntext += "i"
else:
if ntext.endswith("d"):
ntext += "" ntext += ""
elif ntext.endswith("d"):
ntext += "e"
else: else:
ntext += "ov" ntext += "ov"
if nnum >= 10**2 and self.ordflag == False:
ctext += " " ctext += " "
val = cnum * nnum val = cnum * nnum
else: else:
if nnum < 10 < cnum < 100: if nnum < 10 < cnum < 100:
if nnum == 1:
ntext = "ena"
ntext, ctext = ctext, ntext + "in" ntext, ctext = ctext, ntext + "in"
elif cnum >= 10**6: elif cnum >= 10**2 and self.ordflag == False:
ctext += " " ctext += " "
val = cnum + nnum val = cnum + nnum
@@ -101,13 +121,13 @@ class Num2Word_SL(Num2Word_EU):
if outword.endswith(key): if outword.endswith(key):
outword = outword[:len(outword) - len(key)] + self.ords[key] outword = outword[:len(outword) - len(key)] + self.ords[key]
break break
return outword + "te" return outword + "i"
# Is this correct?? # Is this correct??
def to_ordinal_num(self, value): def to_ordinal_num(self, value):
self.verify_ordinal(value) self.verify_ordinal(value)
return str(value) + "te" return str(value) + "."
def to_currency(self, val, longval=True, old=False): def to_currency(self, val, longval=True, old=False):
@@ -138,9 +158,8 @@ def main():
n2w.test(val) n2w.test(val)
n2w.test(1325325436067876801768700107601001012212132143210473207540327057320957032975032975093275093275093270957329057320975093272950730) n2w.test(1325325436067876801768700107601001012212132143210473207540327057320957032975032975093275093275093270957329057320975093272950730)
print n2w.to_currency(112121) print(n2w.to_currency(112121))
print n2w.to_year(2000) print(n2w.to_year(2000))
if __name__ == "__main__": if __name__ == "__main__":
main() main()

55
tests/test_sl.py Normal file
View File

@@ -0,0 +1,55 @@
# -*- encoding: utf-8 -*-
# Copyright (c) 2015, Savoir-faire Linux inc. All Rights Reserved.
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 2.1 of the License, or (at your option) any later version.
# This library is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
# You should have received a copy of the GNU Lesser General Public
# License along with this library; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
# MA 02110-1301 USA
from __future__ import unicode_literals
from unittest import TestCase
from num2words import num2words
class Num2WordsDETest(TestCase):
def test_ordinal_less_than_twenty(self):
self.assertEqual(num2words(2, ordinal=True, lang='sl'), "drugi")
self.assertEqual(num2words(4, ordinal=True, lang='sl'), "četrti")
self.assertEqual(num2words(7, ordinal=True, lang='sl'), "sedmi")
self.assertEqual(num2words(8, ordinal=True, lang='sl'), "osmi")
self.assertEqual(num2words(12, ordinal=True, lang='sl'), "dvanajsti")
self.assertEqual(num2words(17, ordinal=True, lang='sl'), "sedemnajsti")
def test_ordinal_more_than_twenty(self):
self.assertEqual(num2words(81, ordinal=True, lang='sl'), "enainosemdeseti")
def test_ordinal_at_crucial_number(self):
self.assertEqual(num2words(100, ordinal=True, lang='sl'), "stoti")
self.assertEqual(num2words(1000, ordinal=True, lang='sl'), "tisoči")
self.assertEqual(num2words(4000, ordinal=True, lang='sl'), "štiritisoči")
self.assertEqual(num2words(2000000, ordinal=True, lang='sl'), "dvemiljonti")
self.assertEqual(num2words(5000000000, ordinal=True, lang='sl'), "petmiljardti")
def test_cardinal_at_some_numbers(self):
self.assertEqual(num2words(2, lang='sl'), "dve")
self.assertEqual(num2words(4000, lang='sl'), "štiri tisoč")
self.assertEqual(num2words(2000000, lang='sl'), "dva miljona")
self.assertEqual(num2words(4000000000, lang='sl'), "štiri miljarde")
def test_cardinal_for_decimal_number(self):
self.assertEqual(num2words(3.486, lang='sl'), "tri celih štiri osem")
def test_ordinal_for_negative_numbers(self):
self.assertRaises(TypeError, num2words, -12, ordinal=True, lang='sl')
def test_ordinal_for_floating_numbers(self):
self.assertRaises(TypeError, num2words, 2.453, ordinal=True, lang='sl')