鉴于
>>> li = [('Replicate 1', '_E748_.txt'),
... ('Replicate 1', '_E749_.txt'),
... ('Replicate 2', '_E758_.txt'),
... ('Replicate 2', '_E759_.txt')]
做
>>> d = {}
>>> for k, v in li:
... d.setdefault(k, []).append(v)
...
>>> d
{'Replicate 2': ['_E758_.txt', '_E759_.txt'], 'Replicate 1': ['_E748_.txt', '_E749_.txt']}
或者
>>> from collections import defaultdict
>>> d2 = defaultdict(list)
>>> for k, v in li:
... d2[k].append(v)
...
>>> d2
defaultdict(<type 'list'>, {'Replicate 2': ['_E758_.txt', '_E759_.txt'], 'Replicate 1': ['_E748_.txt', '_E749_.txt']})
甚至过于花哨
>>> from itertools import groupby
>>> from operator import itemgetter
>>> get0, get1 = itemgetter(0), itemgetter(1)
>>> dict((key, list(map(get1, subit))) for key, subit in groupby(sorted(li), get0))
{'Replicate 2': ['_E758_.txt', '_E759_.txt'], 'Replicate 1': ['_E748_.txt', '_E749_.txt']}
你尝试过什么吗? –