1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
| # -*- coding: utf-8 -*-
|
| from __future__ import division, print_function, unicode_literals
|
| from . import lang_EU
|
|
| class Num2Word_SV(lang_EU.Num2Word_EU):
| GIGA_SUFFIX = "iljarder"
| MEGA_SUFFIX = "iljoner"
|
| def set_high_numwords(self, high):
| cap = 3 + 6 * len(high)
|
| for word, n in zip(high, range(cap, 3, -6)):
| if self.GIGA_SUFFIX:
| self.cards[10 ** n] = word + self.GIGA_SUFFIX
|
| if self.MEGA_SUFFIX:
| self.cards[10 ** (n - 3)] = word + self.MEGA_SUFFIX
|
| def setup(self):
| super(Num2Word_SV, self).setup()
|
| self.negword = "minus "
| self.pointword = "komma"
| self.exclude_title = ["och", "komma", "minus"]
|
| self.mid_numwords = [(1000, "tusen"), (100, "hundra"),
| (90, "nittio"), (80, "åttio"), (70, "sjuttio"),
| (60, "sextio"), (50, "femtio"), (40, "förtio"),
| (30, "trettio")]
| self.low_numwords = ["tjugo", "nitton", "arton", "sjutton",
| "sexton", "femton", "fjorton", "tretton",
| "tolv", "elva", "tio", "nio", "åtta",
| "sju", "sex", "fem", "fyra", "tre", "två",
| "ett", "noll"]
| self.ords = {"noll": "nollte",
| "ett": "första",
| "två": "andra",
| "tre": "tredje",
| "fyra": "fjärde",
| "fem": "femte",
| "sex": "sjätte",
| "sju": "sjunde",
| "åtta": "åttonde",
| "nio": "nionde",
| "tio": "tionde",
| "elva": "elfte",
| "tolv": "tolfte",
| "tjugo": "tjugonde"}
|
| def merge(self, lpair, rpair):
| ltext, lnum = lpair
| rtext, rnum = rpair
| if lnum == 1 and rnum < 100:
| return (rtext, rnum)
| elif 100 > lnum > rnum:
| return ("%s%s" % (ltext, rtext), lnum + rnum)
| elif lnum >= 100 > rnum:
| return ("%s%s" % (ltext, rtext), lnum + rnum)
| elif rnum >= 1000000 and lnum == 1:
| return ("%s %s" % ('en', rtext[:-2]), lnum + rnum)
| elif rnum >= 1000000 and lnum > 1:
| return ("%s %s" % (ltext, rtext), lnum + rnum)
| elif rnum > lnum:
| return ("%s%s" % (ltext, rtext), lnum * rnum)
| return ("%s %s" % (ltext, rtext), lnum + rnum)
|
| def to_ordinal(self, value):
| self.verify_ordinal(value)
| outwords = self.to_cardinal(value).split(" ")
| lastword = outwords[-1]
| ending_length = 0
| try:
| lastword_ending = self.ords[lastword[-4:]]
| ending_length = 4
| except KeyError:
| try:
| lastword_ending = self.ords[lastword[-3:]]
| ending_length = 3
| except KeyError:
| lastword_ending = "de"
| if lastword_ending == 'de':
| lastword_first_part = self.title(lastword)[:]
| else:
| lastword_first_part = self.title(lastword)[:-ending_length]
| lastword_correct = lastword_first_part + lastword_ending
| outwords[-1] = lastword_correct
| return " ".join(outwords)
|
| def to_ordinal_num(self, value):
| raise NotImplementedError(
| "'ordinal_num' is not implemented for swedish language")
|
| def to_year(self, val, longval=True):
| raise NotImplementedError(
| "'year' is not implemented for swedish language")
|
| def to_currency(self, val, longval=True):
| raise NotImplementedError(
| "'currency' is not implemented for swedish language")
|
|