軽量のpandas Panelインスタンスを後で使用するためにディスクに出力する必要があるケースはたくさんあります。現在、私はpandas.read_pickleが直接Panelオブジェクトとしてそれを取得できるので、pickleオブジェクトとして格納します。しかし、これを行うには2つの落とし穴があります:まず、ファイル名にPanelオブジェクトであることを常にメモしなければなりません。第二に、これは将来どのようなリスクがありますか?たとえば、将来のバージョンのパンダではこれをサポートしていない可能性があり、直接パネルとしてのデータへのアクセスが失われる可能性があります。 Panelオブジェクトを安全に保管するための他の代替方法は何ですか?一方、PanelオブジェクトをPanelとして直接読み取るのは簡単ですか?私はまた、フォーマットをExcelに書き込むこともできましたが、データフレームを1つずつ読み込んで、データを戻すときにPanelに再度結合する必要があります。パンダパネルインスタンスの保存方法は?
2
A
答えて
2
ストレージとしてHDFを使用できます。
デモ:
はのは、財務データとパネルを生成してみましょう:
In [10]: p.axes
Out[10]:
[Index(['Open', 'High', 'Low', 'Close', 'Volume', 'Adj Close'], dtype='object'),
DatetimeIndex(['2016-01-04', '2016-01-05', '2016-01-06', '2016-01-07', '2016-01-08', '2016-01-11', '2016-01-12', '2016-01-13', '2016-01-14',
'2016-01-15',
...
'2017-02-02', '2017-02-03', '2017-02-06', '2017-02-07', '2017-02-08', '2017-02-09', '2017-02-10', '2017-02-13', '2017-02-14',
'2017-02-15'],
dtype='datetime64[ns]', name='Date', length=283, freq=None),
Index(['AAPL', 'FB', 'GOOG'], dtype='object')]
HDF5ファイルに保存:
import pandas as pd
import pandas_datareader.data as wb
stocks = ['AAPL', 'GOOG', 'FB']
p = wb.DataReader(stocks, 'yahoo', '2016-01-01')
は、今、私たちは、次のパネルを持っている
In [12]: p.to_hdf('c:/temp/panel.h5', 'p', format='t')
チェck:
In [13]: store = pd.HDFStore('c:/temp/panel.h5')
In [14]: store
Out[14]:
<class 'pandas.io.pytables.HDFStore'>
File path: c:/temp/panel.h5
/p wide_table (typ->appendable,nrows->849,ncols->6,indexers->[major_axis,minor_axis])
In [15]: store.get_storer('p')
Out[15]: wide_table (typ->appendable,nrows->849,ncols->6,indexers->[major_axis,minor_axis])
In [16]: store.get_storer('p').table
Out[16]:
/p/table (Table(849,)) ''
description := {
"major_axis": Int64Col(shape=(), dflt=0, pos=0),
"minor_axis": StringCol(itemsize=4, shape=(), dflt=b'', pos=1),
"values_block_0": Float64Col(shape=(6,), dflt=0.0, pos=2)}
byteorder := 'little'
chunkshape := (1092,)
autoindex := True
colindexes := {
"major_axis": Index(6, medium, shuffle, zlib(1)).is_csi=False,
"minor_axis": Index(6, medium, shuffle, zlib(1)).is_csi=False}
In [17]: x = store['p']
In [18]: x
Out[18]:
<class 'pandas.core.panel.Panel'>
Dimensions: 6 (items) x 283 (major_axis) x 3 (minor_axis)
Items axis: Open to Adj Close
Major_axis axis: 2016-01-04 00:00:00 to 2017-02-15 00:00:00
Minor_axis axis: AAPL to GOOG
In [20]: x.loc[:,:,'GOOG']
Out[20]:
Open High Low Close Volume Adj Close
2016-01-04 743.000000 744.059998 731.257996 741.840027 3272800.0 741.840027
2016-01-05 746.450012 752.000000 738.640015 742.580017 1950700.0 742.580017
2016-01-06 730.000000 747.179993 728.919983 743.619995 1947000.0 743.619995
2016-01-07 730.309998 738.500000 719.059998 726.390015 2963700.0 726.390015
2016-01-08 731.450012 733.229980 713.000000 714.469971 2450900.0 714.469971
2016-01-11 716.609985 718.854980 703.539978 716.030029 2090600.0 716.030029
2016-01-12 721.679993 728.750000 717.317017 726.070007 2024500.0 726.070007
2016-01-13 730.849976 734.739990 698.609985 700.559998 2501700.0 700.559998
2016-01-14 705.380005 721.924988 689.099976 714.719971 2225800.0 714.719971
2016-01-15 692.289978 706.739990 685.369995 694.450012 3592400.0 694.450012
...
関連する問題
- 1. アレイの保存方法は?
- 2. カメラインスタンスの保存方法は?
- 3. ArrayBufferの保存方法は?
- 4. Bashでコマンドの出力を保存/保存する方法は?
- 5. 保存方法アプリケーションデータ
- 6. オーバーライドスプリングデータ保存方法
- 7. SKPaymentトランザクションを保存または保存する方法は?
- 8. ユニティシェーダのuvパラメータの保存方法は?
- 9. SASライブラリの保存方法
- 10. フェッチデータの保存方法
- 11. Bukkitデータの保存方法
- 12. scapyパケットデータの保存方法は?
- 13. ResourceBaseの保存と復元方法は?
- 14. バッチ作業での保存方法は?
- 15. elastocsearchデータベースの保存方法は?
- 16. firebaseインスタンスIDトークンの保存方法は?
- 17. ラジオボタン選択の保存方法は?
- 18. 36ビットイメージの保存方法は?
- 19. 多言語データの保存方法は?
- 20. SMS情報の保存方法は?
- 21. VMware Fusion VMの保存方法は?
- 22. アルゴリズムの保存と使用方法は?
- 23. ノードjs保存方法PUT
- 24. SAMLクライアントID保存方法
- 25. Laravel hasOne保存方法ID
- 26. 保存する方法データ
- 27. ManyToManyレコードを保存する方法は?
- 28. シリアルXMLのロード方法または保存方法
- 29. Excel 2016 VBA強制的に.xlsmに保存 - テンプレートの保存方法は?
- 30. テキストファイルに保存されたキーを保存する方法