import sys
words = {
1 : 'one',
2 : 'two',
3 : 'three',
4 : 'four',
5 : 'five',
6 : 'six',
7 : 'seven',
8 : 'eight',
9 : 'nine',
10 : 'ten',
11 : 'eleven',
12 : 'twelve',
13 : 'thirteen',
14 : 'fourteen',
15 : 'fifteen',
16 : 'sixteen',
17 : 'seventeen',
18 : 'eighteen',
19 : 'nineteen'
}
tens = [
'',
'twenty',
'thirty',
'forty',
'fifty',
'sixty',
'seventy',
'eighty',
'ninety',
]
placeholders = [
'',
'thousand',
'million',
'billion',
'trillion',
'quadrillion'
]
def convertTrio(number):
return ' '.join([words[int(number[0])], 'hundred', convertDuo(number[1:3])])
def convertDuo(number):
if int(number[0]) == 1:
return words[int(number)]
else:
return tens[int(number[0]) - 1] + '-' + words[int(number[1])]
if __name__ == "__main__":
string = []
numeralSegments = []
numeral = sys.argv[1]
if int(numeral) < 100:
print convertDuo(numeral)
else:
for i in range (0, len(numeral), 3):
numeralSegments.append(numeral[i:i+3])
numeralSegments.reverse()
for i in range (len(numeralSegments)):
string.append(convertTrio(numeralSegments[i]) + ' ' + placeholders[i])
string.reverse()
print ', '.join(string)
Warning . I am a complete newbie in python. I know that there are probably many times more effective ways to do something. I would appreciate any pointers to them.
Change . The code currently only works for numbers whose number of digits is a multiple of three. I would be grateful for the suggestion of an elegant way to fix this. Thank.