[英]Python 3.3: Output of Anagram Function
def anagram(word,check):
for letter in word:
if letter in check:
check = check.replace(letter, '')
else:
return 0
return 1
while True:
f = open('dictionary.txt', 'r')
try:
user_input = input('Word? ')
for word in f:
word = word.strip()
if len(word)==len(user_input):
if word == user_input:
continue
elif anagram(word, input):
print (word)
#try:
#if word == 1:
#print ('The only anagram for', user_input, 'is', word)
#elif word > 1:
#print ('The anagrams for', user_input, 'are', word)
#except TypeError:
#pass
except EOFError:
break
f.close()
该函数可以按我希望的方式工作,但是我需要输出帮助。 我希望输出在一行中,并且措辞应反映找到的字谜的数量。 (即“只有一个字谜”,“字谜是”,“没有字谜”或“单词不在词典中”)代码中的注释是我尝试过的。 谢谢你的帮助。
以我对程序的理解方式,您是否要不断提示用户输入单词,直到他按Ctrl-D(这会导致EOF错误并破坏循环)? 在这种情况下,您应该在循环开始之前仅读取一次文件,并在其中构造一个列表或一组单词。 另外,您的try / except语句应仅包含对input
的调用,因为这是函数中可能发生此异常的唯一位置。
现在,您的主要问题-计算结果的数量并相应地打印不同的语句,只需使用列表推导即可获得所有输入字谜的列表。 然后,您可以计算字谜并将它们连接在一起以形成输出字符串。
def find_anagrams():
with open("dictionary.txt", "r") as fileInput:
words = set(word.strip() for word in fileInput)
while True:
try:
user_input = input("Word? ").strip()
except:
break #you probably don't care for the type of exception here
anagrams = [word for word in words if anagram(word, user_input)]
print_results(anagrams)
def print_results(anagrams):
if len(anagrams) == 0:
print("there are no anagrams")
elif len(anagrams) == 1:
print("the only anagram is %s" % anagrams[0])
else:
print("there are %s anagrams: %s" % (len(anagrams), ', '.join(anagrams)))
该代码唯一缺少的是,使输入的单词不属于结果列表,但可以将其移至anagram
函数。 也可以使用内置collections模块中的Counter类简化该功能。 此类是一个类似于字典的对象,可以从可迭代对象构造该对象,并将可迭代对象中的每个对象映射到其出现的次数:
>>> Counter("hello") == {"h":1, "e":1, "l":2, "o": 1}
True
因此,我们可以像这样重写字谜函数:
from collections import Counter
def anagram(word, check):
return not word == check and Counter(word) == Counter(check)
您可以使用以下结果创建一个列表:
with open("dictionary.txt", "r") as fileInput:
user_input = input("Search keyword: ").strip()
listAnagrams = []
for line in fileInput.readlines():
for word in line.split(" "):
if len(word) == len(user_input):
if word == user_input:
continue
elif anagram(word, user_input):
listAnagrams.append(word)
if len(listAnagrams) == 1:
print ('The only anagram for', user_input, 'is', listAnagrams[0])
elif len(listAnagrams) > 1:
print ('The anagrams for', user_input, 'are', ", ".join(listAnagrams))
else:
print ('No anagrams found for', user_input)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.