我正在运行多个线程,并在队列中收集结果。我想把它转储到数组或列表中,这样我就可以索引和检索这些结果。队列中的每个元素都是一个维度n的数组。我想访问这些数组。你能告诉我,我怎么做吗?
def dump_queue(model_queue):
queue_list = []
for i in iter(model_queue.get,'STOP'):
queue_list.append(i)
return queue_list
aux_model=train_svm(np.array(trainExample),np.array(trainLabel))
model_queue.put(aux_model.coef_)
因此,数组是svm
的学习模型参数。模型队列在线程之间共享。我想访问每个模型参数向量,而不是模型参数的每个条目。
我将采用以下解决方案:
现在,您可以通过索引或切片轻松访问这些值:
因为list()创建了一个q的副本,所以您应该关注队列的维度。执行此操作所需的时间会随着队列长度的增加而增加。另一种方法是使用itertools.islice,在将结果存储在列表中之前,首先对队列进行切片。请查看以下链接(此处还提供了性能度量):
Use slice notation with collections.deque
How to slice a deque? [duplicate]
不知道是不是同一个问题,但我需要做同样的事情,最后写了这个。我在Python2.7中使用threading.Thread和Queue对象。只想把一个队列排成一个列表。
你已经完成了平行部分,只想在列表中得到结果,是吗?然后尝试:
示例:
输出:
相关问题 更多 >
编程相关推荐