我对以下代码的输出是只保存结果的最后一行,而不是将每一行值放入csv文件中。我对python的知识有限。我认为我的循环部分是不正确的。有人能帮我吗?你知道吗
代码
import numpy as np
from numpy import genfromtxt
with open('binary.csv') as actg:
actg=actg.readlines()
with open('single.csv') as single:
single=single.readlines()
with open('division.csv') as division:
division=division.readlines()
for line in actg:
for line2 in single:
for line1 in division:
myarray = np.fromstring(line, dtype=float, sep=',')
myarray = myarray.reshape((-1, 3, 4))
a=np.asmatrix(myarray)
a=np.array(a)
single1 = np.fromstring(line2, dtype=float, sep=',')
single1 = single1.reshape((-1, 4))
s=np.asmatrix(single1)
s=np.array(s)
division1 = np.fromstring(line1, dtype=float, sep=',')
m=np.asmatrix(division1)
m=np.array(m)
res2 = (s[np.newaxis,:,:] / m[:,np.newaxis,:] * a).sum(axis=-1)
np.savetxt("output.csv", res2, delimiter=",")
二进制.csv
0,1,0,0,1,0,0,0,0,0,0,1
0,0,1,0,1,0,0,0,1,0,0,0
单个.csv:
0.28,0.22,0.23,0.27,0.12,0.29,0.34,0.21,0.44,0.56,0.51,0.65
部门.csv
0.4,0.5,0.7,0.1
0.2,0.8,0.9,0.3
预期产量
0.44,0.3,6.5
0.26,0.6,2.2
实际产量
0.26,0.6,2.2
这不是你的理解。这是你对循环逻辑的理解。你知道吗
如果仔细观察循环,您(而不是Python)总是保留最后的元素。你知道吗
在第一个和第二个循环中,每次覆盖所需的变量时,都不保留每次迭代的总体信息。你知道吗
在最后一个循环中,在每次迭代中将
row
变量声明为新列表。你知道吗此外,
i
变量除了作为for循环中的索引变量外,不会在任何地方设置!你知道吗因为循环结束后才写出结果,所以只能看到最后一个结果。
另外,我希望从该数据中得到4个结果,而不是2个。
您需要在每次迭代中写入输出或存储每次迭代,然后写出存储的值。
每次计算时,请尝试打印
res2
,您将看到如下内容:相关问题 更多 >
编程相关推荐