46

できるだけわかりやすくするために、まず、なぜ 2 つの配列を行列に変換する必要があるのか​​を説明します。

ポートフォリオと市場指数のパフォーマンスをプロットするには、次の形式のようなデータ構造が必要です。

[[portfolio_value1, index_value1]
 [portfolio_value2, index_value2]]

しかし、私はデータを 2 つの別個の 1-D 配列として持っています。

portfolio = [portfolio_value1, portfolio_value2, ...]
index = [index_value1, index_value2, ...]

では、2 番目のシナリオを最初のシナリオに変換するにはどうすればよいでしょうか。Pythonシェルにあるテストマトリックスに2番目の配列を追加しようとしましnp.insertたが、最初の配列を単一の列マトリックスに転置することが問題でした。

命令型ループなしでこれを達成する方法についての助けは素晴らしいでしょう。

4

4 に答える 4

104

あなたが望むものの標準的なnumpy関数は次のnp.column_stackとおりです。

>>> np.column_stack(([1, 2, 3], [4, 5, 6]))
array([[1, 4],
       [2, 5],
       [3, 6]])

あなたportfolioindex配列を使って、

np.column_stack((portfolio, index))

次のような結果が得られます。

[[portfolio_value1, index_value1],
 [portfolio_value2, index_value2],
 [portfolio_value3, index_value3],
 ...]
于 2013-09-10T23:25:03.900 に答える
5

ポートフォリオとインデックスの長さが同じであると仮定します。

matrix = []
for i in range(len(portfolio)):
    matrix.append([portfolio[i], index[i]])

または、リスト内包表記を使用したワンライナー:

matrix2 = [[portfolio[i], index[i]] for i in range(len(portfolio))]
于 2013-09-10T23:03:28.743 に答える