In [514]: test
Out[514]:
{'file1': {'subfile1': [1, 2, 3], 'subfile2': [10, 11, 12]},
'file2': {'subfile1': [4, 78, 6]},
'file3': {'subfile1': [7, 8, 9]},
'file5': {'subfile1': [4, 678, 6]}}
In [515]: data=[test[f]['subfile1'] for f in test]
In [516]: data
Out[516]: [[1, 2, 3], [4, 78, 6], [7, 8, 9], [4, 678, 6]]
In [517]: np.array(data)
Out[517]:
array([[ 1, 2, 3],
[ 4, 78, 6],
[ 7, 8, 9],
[ 4, 678, 6]])
あなたは、反復的にリストを作成しなければならない場合:
In [518]: data=[]
In [519]: for f in test.keys():
...: data.append(test[f]['subfile1'])
をあなたが各ステップで連結できます。
In [521]: testarray=np.array([50,60,70])
In [522]: for file in test.keys():
...: testarray = np.concatenate((testarray, test[file]['subfile1']))
...:
In [523]: testarray
Out[523]:
array([ 50, 60, 70, 1, 2, 3, 4, 78, 6, 7, 8, 9, 4, 678, 6])
お知らせこのプットを以前のメソッドが行った2次元配列とは対照的に、1つの1次元配列内のすべての値。私たちは012dを行くvstack
(それもconcatenate
を使用します)。
In [525]: testarray=np.array([50,60,70])
In [526]: for file in test.keys():
...: testarray = np.vstack((testarray, test[file]['subfile1']))
...:
...:
In [527]: testarray
Out[527]:
array([[ 50, 60, 70],
[ 1, 2, 3],
[ 4, 78, 6],
[ 7, 8, 9],
[ 4, 678, 6]])
私もappend
でこれを書くことができますが、私はむしろないと思います。あまりにも多くのポスターがそれを悪用します。
は何をしていますか?コードを表示するだけではありません。結果を表示し、何が間違っているか説明してください。 – hpaulj