Python:从列表列表中计算元素数量并将数据输入到Matrix?

时间:2016-07-05 15:38:35

标签: python python-3.x for-loop counter python-xarray

给出一个列表列表,其中每个列表的长度为

 M = [[1,2,3,4,4,5,1,2,9,0], [3,2,1,0,5,6,2,4,6,7], [4,5,5,2,1,2,3,4,2,4], [7,5,6,2,6,7,8,8,8,1] ]

我想计算一个元素的重复次数,并将其输入一个单独的矩阵。

让我们将每个列表称为frame,将帧中的元素称为states

这是我的代码,它运行正常:

import numpy as np
from collections import Counter
import numpy as np
from xarray import DataArray

def Vfinal(s_t,Matrix):
    state_no = np.arange(0,s_t)
    frame_no = np.arange(0,len(Matrix))                  
    V= DataArray(np.zeros(( len(state_no),len(Matrix) )), coords=[('States_count', state_no), ('Frame',frame_no)])
    for i,j in enumerate(Matrix):
        for k in j:
            print(k,i)
            V.loc[k,i] +=1
    return  V

In [172]: V = Vfinal(10,M)

In [173]: V
Out[173]:
<xarray.DataArray (States_count: 10, Frame: 4)>
array([[ 1.,  1.,  0.,  0.],
       [ 2.,  1.,  1.,  1.],
       [ 2.,  2.,  3.,  1.],
       [ 1.,  1.,  1.,  0.],
       [ 2.,  1.,  3.,  0.],
       [ 1.,  1.,  2.,  1.],
       [ 0.,  2.,  0.,  2.],
       [ 0.,  1.,  0.,  2.],
       [ 0.,  0.,  0.,  3.],
       [ 1.,  0.,  0.,  0.]])
Coordinates:
  * States_count  (States_count) int64 0 1 2 3 4 5 6 7 8 9
  * Frame         (Frame) int64 0 1 2 3

在我的情况下,列表M具有28,800 lists,其中每个列表包含75个元素(0到499之间的数字)。

这使得矩阵的大小为500X 28,800。代码需要30分钟(大约)才能完成,我认为问题出在for循环中。

是否有任何有效的编写方式,以便可以更快地执行代码?

1 个答案:

答案 0 :(得分:2)

我将功能Vfinal更改为Vfinal2

这使代码更快

def Vfinal2(s_t,Matrix):
        V = np.zeros((s_t,len(Matrix)))
        for i,row in enumerate(Matrix):
            a = np.bincount(row)
            b=np.zeros(s_t)
            b[:len(a)]=a
            V[:,i]=b
    return V