回答此问题可获得 20 贡献值,回答如果被采纳可获得 50 分。
<p>我一直在努力改变这个测试.csv文件:</p>
<pre><code>a,b,4
a,c,2
b,a,4
b,c,1
b,d,5
c,a,2
c,b,1
c,d,8
c,e,10
d,b,5
d,c,8
d,e,2
d,z,6
e,c,10
e,d,2
e,z,3
z,d,6
z,e,3
</code></pre>
<p>转换成这种格式。到目前为止,当我尝试转换它时,重复的键被覆盖,而不是作为第二个值添加。有人能告诉我怎么得到这个格式吗?你知道吗</p>
<pre><code>G1 = {
'a': [('b', 4), ('c', 2)],
'b': [('a', 4), ('c', 1), ('d', 5)],
'c': [('a', 2), ('b', 1), ('d', 8), ('e', 10)],
'd': [('b', 5), ('c', 8), ('e', 2), ('z', 6)],
'e': [('c', 10), ('d', 2), ('z', 3)],
'z': [('d', 6), ('e', 3)],
}
</code></pre>
<p>这是将文件转换为dict的代码,但会替换重复键的新值。我想知道如何将值添加为元组,对于重复的键,将元组添加为第二个值。你知道吗</p>
<pre><code>reader = csv.reader(open('test.csv'))
arcos = {}
for row in reader:
key = row[0]
arcos[key] = row[1:]
</code></pre>
<p>结果是:</p>
<pre><code>{
'a': ['c', 2.0],
'b': ['d', 5.0],
'c': ['e', 10.0],
'd': ['z', 6.0],
'e': ['z', 3.0],
'z': ['e', 3.0]
}
</code></pre>
<p>我希望我所要求的是可能的。你知道吗</p>