首页 > 解决方案 > 删除属于另一个单词的单词

问题描述

假设我在 python 中有一个字符串列表,例如 -

lst = ['makeup brush tool', 'mak', 'flawless', 'tool', 'makeu', 'bru', 'brus', 'brush', 'makeup brush', 'cosmetic brush holder', 'elf makeup', 'key holder', 'holder', 'flaw', 'flawl', 'marinade brush', 'cosmetic', 'makeup brush cleaner', 'makeup brush holder', 'brush holder']

现在像“mak”这样的单个词是另一个词“makeu”的一部分。如何删除像“mak”这样的词。更多示例 - 出“bru”、“brus”和“brush” -> 必须删除“bru”和“brus”。

在此之后我无法继续 -

def remove_repeated_parts(un_corrected):
    """ Returns a corrected list """
    corrected = []
    for word in un_corrected:
        string_split = word.split()
        if len(string_split) == 1:
             # what to do from here


remove_repated_parts(lst)

预期产出 -

lst = ['makeup brush tool', 'flawless', 'tool', 'makeu', 'brush', 'makeup brush', 'cosmetic brush holder', 'elf makeup', 'key holder', 'holder', 'marinade brush', 'cosmetic', 'makeup brush cleaner', 'makeup brush holder', 'brush holder']

请注意,我们只考虑长度为 1 的字符串

与正则表达式有什么关系吗?

标签: pythonregexlist

解决方案


你可以试试这个:(不使用正则表达式)

lst = ['makeup brush tool', 'mak', 'flawless', 'tool', 'makeu', 'bru', 'brus', 'brush', 'makeup brush', 'cosmetic brush holder', 'elf makeup', 'key holder', 'holder', 'flaw', 'flawl', 'marinade brush', 'cosmetic', 'makeup brush cleaner', 'makeup brush holder', 'brush holder']
def check_list(lists,l=[]):
    for m in lists:
        for n in lists:
            if m in n:
                l.append(n)
                break
    return l
print(check_list(lst))

推荐阅读