来自Words.list的单词搜索者

时间:2017-12-18 17:14:20

标签: python string list wordsearch

我在早些时候帮助我的妈妈使用这个单词搜索应用程序,同时从一些python教程中休息一下,我意识到 - 这是一个有趣的事情的完美例子,供我学习/学习。

这是我想出的,虽然它有效,但我必须做一些额外的步骤来弄清楚这些词。

似乎我的双重角色没有注册为两个,其中一个被替换为不相关的字母。

我尝试过很多不同的东西 - 弹出,删除。用于单词而不是myletters中的字符(以减去差异)。我发现涉及这些东西的很多东西都是网格和方向,但我真的只对我的字符输入中的单词列表感兴趣。任何帮助表示赞赏。

旁注 - 我对编码非常陌生,所以如果这是合适的路线就是idk。这个x比我能找到的任何例子都简单x * 10。 (也许为什么它不按照我想要的方式工作?; p)

wordlist = open("PossibleWords.txt", "r").read().split()
myletters = input("Letters?: ").lower()
s = list()
sorted = str(myletters)

for word in wordlist:
    if len(word) == len(myletters) and all(letter in word for letter in sorted):
        s.append(word)
for length in s[:100]:
print(length)

1 个答案:

答案 0 :(得分:0)

根据OP最近的评论,听起来我们正在进行字搜索。为了不丢失双字母,我们将使用Counter并比较计数器:

from collections import Counter

def is_sub_count(counter_super, counter_sub):

    counter_sub.subtract(counter_super)

    return all(count <= 0 for count in counter_sub.values())

myLetters = input("Letters?: ").lower()
myCount = Counter(myLetters)
myLength = len(myLetters)

words = open("PossibleWords.txt").read().split()

found = list()

for word in words:
    if len(word) <= myLength and is_sub_count(myCount, Counter(word.lower())):
        found.append(word)

print(*found, sep='\n')

<强> USAGE

> python3 test.py
Letters?: uassage
a
age
ague
as
ass
assuage
gas
gauss
guess
sag
saga
sage
sausage
sea
sue
us
usage
use
>