gpt4 book ai didi

python - 在匹配不同字符串列表的位置拆分字符串列表

转载 作者:太空宇宙 更新时间:2023-11-03 12:56:36 24 4
gpt4 key购买 nike

我编写了一个小程序来执行以下操作。我想知道是否有明显更优的解决方案:

1) 获取 2 个字符串列表。一般来说,第二个列表中的字符串会比第一个列表中的字符串长,但这并不保证

2) 返回从第二个列表派生的字符串列表,该列表已从第一个列表中删除所有匹配的字符串。因此,该列表将包含 <= 第二个列表中字符串长度的字符串。

下面我展示了我正在谈论的图片示例: basic outline of what should happen

到目前为止,这就是我所拥有的。它似乎工作正常,但我只是好奇是否有我缺少的更优雅的解决方案。顺便说一句,我正在跟踪字符串每个开始和结束的“位置”,这对于该程序的后面部分很重要。

def split_sequence(sequence = "", split_seq = "", length = 8):
if len(sequence) < len(split_seq):
return [],[]
split_positions = [0]
for pos in range(len(sequence)-len(split_seq)):
if sequence[pos:pos+len(split_seq)] == split_seq and pos > split_positions[-1]:
split_positions += [pos, pos+len(split_seq)]
if split_positions[-1] == 0:
return [sequence], [(0,len(sequence)-1)]
split_positions.append(len(sequence))
assert len(split_positions) % 2 == 0
split_sequences = [sequence[split_positions[_]:split_positions[_+1]] for _ in range(0, len(split_positions),2)]
split_seq_positions = [(split_positions[_],split_positions[_+1]) for _ in range(0, len(split_positions),2)]
return_sequences = []
return_positions = []
for pos,seq in enumerate(split_sequences):
if len(seq) >= length:
return_sequences.append(split_sequences[pos])
return_positions.append(split_seq_positions[pos])
return return_sequences, return_positions





def create_sequences_from_targets(sequence_list = [] , positions_list = [],length=8, avoid = []):
if avoid:
for avoided_seq in avoid:
new_sequence_list = []
new_positions_list = []
for pos,sequence in enumerate(sequence_list):
start = positions_list[pos][0]
seqs, positions = split_sequence(sequence = sequence, split_seq = avoided_seq, length = length)
new_sequence_list += seqs
new_positions_list += [(positions[_][0]+start,positions[_][1]+start) for _ in range(len(positions))]
return new_sequence_list, new_positions_list

示例输出:

In [60]: create_sequences_from_targets(sequence_list=['MPHSSLHPSIPCPRGHGAQKA', 'AEELRHIHSRYRGSYWRTVRA', 'KGLAPAEISAVCEKGNFNVA'],positions_list=[(0, 20), (66, 86), (136, 155)],avoid=['SRYRGSYW'],length=3)
Out[60]:
(['MPHSSLHPSIPCPRGHGAQKA', 'AEELRHIH', 'RTVRA', 'KGLAPAEISAVCEKGNFNVA'],
[(0, 20), (66, 74), (82, 87), (136, 155)])

最佳答案

让我们定义这个字符串 s 和要删除的字符串列表 list1:

>>> s = 'NowIsTheTimeForAllGoodMenToComeToTheAidOfTheParty'
>>> list1 = 'The', 'Good'

现在,让我们删除这些字符串:

>>> import re
>>> re.split('|'.join(list1), s)
['NowIs', 'TimeForAll', 'MenToComeTo', 'AidOf', 'Party']

上面的强大功能之一是 list1 中的字符串可以包含正则表达式激活字符。这也可能是不受欢迎的。正如 John La Rooy 在评论中指出的那样,list1 中的字符串可以通过以下方式变为非事件状态:

>>> re.split('|'.join(re.escape(x) for x in list1), s)
['NowIs', 'TimeForAll', 'MenToComeTo', 'AidOf', 'Party']

关于python - 在匹配不同字符串列表的位置拆分字符串列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39238984/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com