加入收藏 | 设为首页 | 会员中心 | 我要投稿 阜阳站长网 (https://www.0558zz.com/)- 科技、建站、内容创作、云计算、网络安全!
当前位置: 首页 > 编程开发 > Python > 正文

Python – 从作为另一个元素的子串的字符串列表中删除任何元素

发布时间:2020-09-25 18:32:47 所属栏目:Python 来源:互联网
导读:所以从一个字符串列表开始,如下所示 string_list = [‘rest’, ‘resting’, ‘look’, ‘looked’, ‘it’, ‘spit’] 我想从列表中删除另一个元素的子串的任何元素,给出结果为… string_list = [‘resting’, ‘looked’, ‘spit’] 我有一些代码可以实现这

所以从一个字符串列表开始,如下所示

string_list = [‘rest’,‘resting’,‘look’,‘looked’,‘it’,‘spit’]

我想从列表中删除另一个元素的子串的任何元素,给出结果为…

string_list = [‘resting’,‘spit’]

我有一些代码可以实现这一点,但是令人尴尬的是丑陋,可能不必要的复杂.在Python中有一个简单的方法吗?

解决方法

第一个构建块:子串.

您可以使用来检查:

>>> 'rest' in 'resting'
True
>>> 'sing' in 'resting'
False

接下来,我们将选择创建新列表的天真的方法.我们将逐个添加项目到新的列表中,检查它们是否是子字符串.

def substringSieve(string_list):
    out = []
    for s in string_list:
        if not any([s in r for r in string_list if s != r]):
            out.append(s)
    return out

您可以通过排序来减少比较数量(毕竟更长的字符串永远不会是较短/等长的字符串的子字符串):

def substringSieve(string_list):
    string_list.sort(key=lambda s: len(s),reverse=True)
    out = []
    for s in string_list:
        if not any([s in o for o in out]):
            out.append(s)
    return out

(编辑:阜阳站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读