我有一个函数,它接受一个整数作为输入,并将数字作为单词返回,除了30,40,50,60,70,80
和90
之外,它可以正常工作,它返回90 = ninty zero
,因为该功能通过分割数字来工作,我如何删除为上述数字添加的零。我的代码如下
d = {0: 'zero', 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: 'ninteen', 20: 'twenty',
30: 'thirty', 40: 'fourth', 50: 'fifty', 60: 'sixty',
70: 'seventy', 80: 'eighty', 90: 'ninty'}
def wordify(n):
k = 1000
m = k * 1000
if n < 20:
return d[n]
if n < 100:
if n % 100 == 0: return d[n]
else: return d[n // 10 * 10] + ' ' + d[n % 10]
if n < k:
if n % 100 == 0: return d[n // 100] + ' hundred'
else: return d[n // 100] + ' hundred ' + wordify(n % 100)
if n < m:
if n % k == 0: return wordify(n // k) + ' thousand'
else: return wordify(n // k) + ' thousand, ' + wordify(n % k)
print wordify(90)
答案 0 :(得分:1)
更改以下行:
if n % 100 == 0: return d[n]
到
if n % 10 == 0: return d[n]
解决了这个问题。因为它将始终使用单个单词,并且只要它是10的倍数就不会在其后面添加零。
答案 1 :(得分:0)
只需执行额外的通行证即可解决问题。有时比试图弄清楚如何避免它们更简单。
print wordify(90).replace(" zero","")
或:将您的wordify函数重命名为internal_wordify
,然后像这样定义wordify
:
def wordify(n):
return internal_wordify(n).replace(" zero","")