Reputation: 47316
I have list in python which has following entries
name-1
name-2
name-3
name-4
name-1
name-2
name-3
name-4
name-1
name-2
name-3
name-4
I would like remove name-1 from list except its first appearance -- resultant list should look like
name-1
name-2
name-3
name-4
name-2
name-3
name-4
name-2
name-3
name-4
How to achieve this ?
Upvotes: 3
Views: 6089
Reputation: 186108
Assuming name-1 denotes "the first element":
[names[0]] + [n for n in names[1:] if n != names[0]]
EDIT: If the overall goal is to de-duplicate the entire list, just use set(names)
.
Upvotes: 2
Reputation: 74134
Based on Marcelo's solution:
[name for cnt,name in enumerate(names) if (name != names[0] or cnt > 0)]
Upvotes: 2
Reputation: 3570
mylist = ['name-1', 'name-2', 'name-3', 'name-4', 'name-1', 'name-2', 'name-3', 'name-4', 'name-1', 'name-2', 'name-3', 'name-4']
newlist = filter(lambda x: x != 'name-1', mylist)
newlist.insert(mylist.index('name-1'), 'name-1')
print newlist
['name-1', 'name-2', 'name-3', 'name-4', 'name-2', 'name-3', 'name-4', 'name-2', 'name-3', 'name-4']
Upvotes: 1
Reputation: 30646
Find the index of the first element you wish to remove, then filter the rest of the list. The following works in Python 2.5:
def removeAllButFirst(elem, myList):
idx = myList.index(elem)
return myList[0:idx+1] + filter(lambda x: x != elem, myList[idx+1:])
Upvotes: 1
Reputation: 107786
def remove_but_first( lst, it):
first = lst.index( it )
# everything up to the first occurance of it, then the rest of the list without all it
return lst[:first+1] + [ x for x in lst[first:] if x != it ]
s = [1,2,3,4,1,5,6]
print remove_but_first( s, 1)
Upvotes: 3