我得到了一个40个单词的清单,这些清单是我从txt文件中提取出来的。我找到了重复项,并用相同的单词替换了它们,然后在前后添加了“ *”。代码如下:def show(self, list1): a = [x for x in list1 if list1.count(x) > 1] lista2 = ["*"+s+"*" if s in a else s for s in list1] print(lista2)输入:> ['utanför', 'dörren', 'stod', 'en', 'man', 'och', 'lyssnade', 'intensivt', 'i', 'den', 'mörka', 'korridoren', 'han', 'hade', 'skuggat', 'digby', 'groat', 'hela', 'eftermiddagen', 'och', 'följt', 'efter', 'honom', 'in', 'i', 'huset', 'när', 'han', 'fick', 'hära', 'ljudet', 'av', 'fotsteg', 'från', 'rummet', 'smög', 'han', 'sig', 'in', 'i'] 输出:> ['utanför', 'dörren', 'stod', 'en', 'man', '*och*', 'lyssnade', 'intensivt', '*i*', 'den', 'mörka', 'korridoren', '*han*', 'hade', 'skuggat', 'digby', 'groat', 'hela', 'eftermiddagen', '*och*', 'följt', 'efter', 'honom', '*in*', '*i*', 'huset', 'när', '*han*', 'fick', 'hära', 'ljudet', 'av', 'fotsteg', 'från', 'rummet', 'smög', '*han*', 'sig', '*in*', '*i*']请注意,重复项在*前后都有。TL:DR我希望第一个重复项被忽略,其余的都用*前后突出显示。
3 回答

慕的地6264312
TA贡献1817条经验 获得超6个赞
def show(self, list1):
new_list, seen = [], set()
for x in list1:
if x in seen:
new_list.append('*{0}*'.format(x))
else:
new_list.append(x)
seen.add(x)
print new_list
添加回答
举报
0/150
提交
取消