def soundex(query: str):
""" https://en.wikipedia.org/wiki/Soundex :param query: :return: """
query = query.lower()
letters = [char for char in query if char.isalpha()]
if len(query) == 1:
return query + "000"
to_remove = ('a', 'e', 'i', 'o', 'u', 'y', 'h', 'w')
first_letter = letters[0]
letters = letters[1:]
letters = [char for char in letters if char not in to_remove]
if len(letters) == 0:
return first_letter + "000"
to_replace = {('b', 'f', 'p', 'v'): 1, ('c', 'g', 'j', 'k', 'q', 's', 'x', 'z'): 2,
('d', 't'): 3, ('l',): 4, ('m', 'n'): 5, ('r',): 6}
first_letter = [value if first_letter else first_letter for group, value in to_replace.items()
if first_letter in group]
letters = [value if char else char
for char in letters
for group, value in to_replace.items()
if char in group]
letters = [char for ind, char in enumerate(letters)
if (ind == len(letters) - 1 or (ind+1 < len(letters) and char != letters[ind+1]))]
if first_letter == letters[0]:
letters[0] = query[0]
else:
letters.insert(0, query[0])
first_letter = letters[0]
letters = letters[1:]
letters = [char for char in letters if isinstance(char, int)][0:3]
while len(letters) < 3:
letters.append(0)
letters.insert(0, first_letter)
string = "".join([str(l) for l in letters])
return string
if __name__ == "__main__":
str1 = "how are you"
temp = soundex(str1)
print(temp)
複製代碼