lst = [元素列表] # print(len(lst)) new_lst = [lst[0]] for item in lst[1:]: new_item = item.split(')') new_lst.extend([new_item[0], new_item[1]]) print(len(new_lst)) print(new_lst)
可以得到预期的结果:
后来【甯同学】也给了一个代码,如下图所示:
代码很秀,叹为观止!
后来他自己又遇到了一个新需求,如下图所示:
看上去还是挺复杂的,用上面的代码已经不能满足了,后来他自己提供了一份代码,如下图所示:
l1 = sum([*map((lambda x: x.split(')') if'png)'in x else [x]), lists)], []) l1 = [x for x in l1 if x != ''] l2 = [] nums = [] for j, item in enumerate(l1): if'png'in item: if item[0] != '!': b = ' '.join(l1[j - 1:j + 1]).split('![](') nums.append(j) else: b = item.split('![](') b = [x for x in b if x != ''] l2.extend(b) else: l2.append(item) lists = [l2[j] for j in range(len(l2)) if j+1 not in nums]
相当于方法一和方法二的结合版本,总算搞定了。
后来他发了源码之后,【瑜亮老师】给了一份代码,使用正则表达式很快搞定,代码如下:
import re data = '你上面发的这个字符串' temp = re.findall(r'>(.*?)<|src="(.*?)"', data) result = [i.replace('\u3000', ' ') for j in temp for i in j if i != ''] print(result)