这就是我在提出建议后得出的结论,似乎英语词典和Tuc词典是一样的。这个程序会把英文单词翻译成Tuccin,但我无论如何也不能让它把Tuccin翻译成英语,请告诉我怎么做到这一点。如果输入了非存储的单词,我将其设置为仅打印单词本身。但我甚至不能让elif触发它,如果它不是一个存储的英语单词,它会直接转到else条件。
Tuc={"i":["o"],"love":["wau"],"you":["uo"],"me":["ye"],"my":["yem"],"mine":["yeme"],"are":["sia"]}
Eng = {t: e for t, e in Tuc.items()}
print "ENG"
print Eng
print "TUC"
print Tuc
phrase=True
reverseLookup = False
while phrase == True:
translation = str(raw_input("Enter content for translation.\n").lower())
input_list = translation.split()
for word in input_list:
#English to Tuccin
if word in Tuc:
print ("".join(Tuc[word]))+" *English>>Tuccin"
#Tuccin to English
elif word in Eng:
print ("".join(Eng[word]))+" *Tuccin>>English"
else:
print word+" *Word Not Stored"发布于 2016-09-08 06:28:52
按照您当前设置的方式,Eng和Tuc是相同的。看起来你想要的是
>>> Eng = {e[0]: [t] for t, e in Tuc.items()}
>>> Eng
{'yem': ['my'], 'ye': ['me'], 'uo': ['you'], 'o': ['i'], 'sia': 'are'], 'yeme': ['mine'], 'wau': ['love']}顺便说一句,实际上没有必要在散列列表中创建值,因为它们都包含单个字符串,但这并不是什么大问题。
发布于 2016-09-08 06:28:59
上面有一个打字错误:
Eng = {e[0]: [t] for t, e in Tuc.items()}发布于 2016-09-08 06:31:02
你应该这样做
eng = {v[0]: [k] for k, v in tuc.items()}或者使用Python2的iteritems()。
注意,而不是:
while phrase == True你应该这样写:
while phrasehttps://stackoverflow.com/questions/39379907
复制相似问题