3

我正在尝试查看一个单词或句子是否具有字母表中的每个字母,但我无法让它打印所有不在句子/单词中的字母。

alpha = ['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t'
,'u','v','w','x','y','z']
x = raw_input('')
counter  = 0
counter2 = 0
for i in range(len(x))
    counter += 1
    for o in range(26):
        counter2 += 1
        if alpha[counter2] not in x[counter]:

我被困在那里......

4

4 回答 4

4
alphabet = {'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t'
,'u','v','w','x','y','z'}
input_chars = set(raw_input())
print alphabet - input_chars

我们所做的只是设置字母字符集和输入中的字符集之间的差异。请注意,差异操作可以将任何可迭代的操作作为第二个操作数,因此如果我们不想,我们甚至不必将输入转换为集合,尽管这会稍微加快差异。此外,有一个内置字符串可以为我们提供 ascii 字母,因此我们可以这样做:

import string
print set(string.ascii_lowercase) - raw_input()
于 2012-10-09T01:06:39.077 回答
2

使用set difference

import string
x=raw_input()
not_found=set(string.ascii_lowercase) - set("".join(x.split()))
print (list(not_found))

输出:

>>> 
the quick brown fox
['a', 'd', 'g', 'j', 'm', 'l', 'p', 's', 'v', 'y', 'z']
于 2012-10-09T01:00:26.863 回答
2

由于您已经在两个字符串上进行迭代,因此无需使用counterand counter2

你快到了。Python 使列表操作变得简单,因此无需使用索引逐个元素地迭代列表:

alphabet = 'abcdefghijklmnopqrstuvwxyz'
sentence = raw_input('Enter a sentence: ').lower()  # Because 'a' != 'A'

letters = []

for letter in sentence:
    if letter in alphabet and letter not in letters:
        letters.append(letter)

print(letters)
于 2012-10-09T01:08:10.607 回答
1

容易得多:

 import string
 x = raw_input()
 print [c for c in string.ascii_lowercase if c not in x]
于 2012-10-09T00:58:04.360 回答