我有一个来自csv文件的代码列表:
file_path = 'c:\\temp\\list.csv'
csvfile = open(file_path, 'rb')
reader = csv.reader(csvfile, delimiter=';')
rr = []
for sor in reader:
if sor[1][0] == '1':
rr.append(sor)
print type(rr)
<type 'list'>
set (rr)
Traceback (most recent call last):
File "<pyshell#85>", line 1, in <module>
set (rr)
TypeError: unhashable type: 'list'
如果我对来自数据库的另一个列表执行相同的操作,它可以正常工作:
cur.execute('select code from mytable')
res = cur.fetchall()
res1 = []
res1.append(x[0] for x in res)
print type(res1)
<type 'list'>
set(res1)
set(['13561255', '11120088'])
rr和res1有何不同?它们都是列表类型。
事实上,我正在通过执行以下操作在数据库中查找不存在于CSV文件中的记录:
result = list(set(res1) - set(rr))
我该如何实现这个(也许更加优化/更快的方式)?