ich habe einige Probleme beim Maskieren eines Panels auf die gleiche Weise wie ich einen DataFrame. Was ich tun möchte, fühlt sich einfach an, aber ich habe keinen Weg gefunden, die Dokumente und Online-Foren zu betrachten. Ich habe ein einfaches Beispiel unter:Boolean Maske in Pandaboard
import pandas
import numpy as np
import datetime
start_date = datetime.datetime(2009,3,1,6,29,59)
r = pandas.date_range(start_date, periods=12)
cols_1 = ['AAPL', 'AAPL', 'GOOG', 'GOOG', 'GS', 'GS']
cols_2 = ['close', 'rate', 'close', 'rate', 'close', 'rate']
dat = np.random.randn(12, 6)
dftst = pandas.DataFrame(dat, columns=pandas.MultiIndex.from_arrays([cols_1, cols_2], names=['ticker','field']), index=r)
pn = dftst.T.to_panel().transpose(2,0,1)
print pn
Out[14]:
<class 'pandas.core.panel.Panel'>
Dimensions: 2 (items) x 12 (major_axis) x 3 (minor_axis)
Items axis: close to rate
Major_axis axis: 2009-03-01 06:29:59 to 2009-03-12 06:29:59
Minor_axis axis: AAPL to GS
ich jetzt ein Panel zum Gegenstand haben, wenn ich eine Scheibe entlang der Elemente Achse nehmen, bekomme ich eine Dataframe
close_p = pn['close']
print close_p
Out[16]:
ticker AAPL GOOG GS
2009-03-01 06:29:59 -0.082203 -0.286354 1.227193
2009-03-02 06:29:59 0.340005 -0.688933 -1.505137
2009-03-03 06:29:59 -0.525567 0.321858 -0.035047
2009-03-04 06:29:59 -0.123549 -0.841781 -0.616523
2009-03-05 06:29:59 -0.407504 0.188372 1.311262
2009-03-06 06:29:59 0.272883 0.817179 0.584664
2009-03-07 06:29:59 -1.767227 1.168876 0.443096
2009-03-08 06:29:59 -0.685501 -0.534373 -0.063906
2009-03-09 06:29:59 0.851820 0.068740 0.566537
2009-03-10 06:29:59 0.390678 -0.012422 -0.152375
2009-03-11 06:29:59 -0.985585 -0.917705 -0.585091
2009-03-12 06:29:59 0.067498 -0.764343 0.497270
ich diese Daten auf zwei Arten filtern :
1) erstellen I eine Maske und die Datenmaske wie folgt:
msk = close_p > 0
close_p = close_p.mask(msk)
2) I durch die boolean op nur schneiden können erator in msk oben
close_p = close_p[close_p > 0]
Out[28]:
ticker AAPL GOOG GS
2009-03-01 06:29:59 NaN NaN 1.227193
2009-03-02 06:29:59 0.340005 NaN NaN
2009-03-03 06:29:59 NaN 0.321858 NaN
2009-03-04 06:29:59 NaN NaN NaN
2009-03-05 06:29:59 NaN 0.188372 1.311262
2009-03-06 06:29:59 0.272883 0.817179 0.584664
2009-03-07 06:29:59 NaN 1.168876 0.443096
2009-03-08 06:29:59 NaN NaN NaN
2009-03-09 06:29:59 0.851820 0.068740 0.566537
2009-03-10 06:29:59 0.390678 NaN NaN
2009-03-11 06:29:59 NaN NaN NaN
2009-03-12 06:29:59 0.067498 NaN 0.497270
Was ich nicht verstehen kann, wie auf einer Maske eine Basis all meine Datenfilter zu tun, ohne für Schleife. Ich kann folgendes tun:
msk = (pn['rate'] > 0) & (pn['close'] > 0)
def mask_panel(pan, msk):
for item in pan.items:
pan[item] = pan[item].mask(msk)
return pan
print pn['close']
Out[32]:
ticker AAPL GOOG GS
2009-03-01 06:29:59 -0.082203 -0.286354 1.227193
2009-03-02 06:29:59 0.340005 -0.688933 -1.505137
2009-03-03 06:29:59 -0.525567 0.321858 -0.035047
2009-03-04 06:29:59 -0.123549 -0.841781 -0.616523
2009-03-05 06:29:59 -0.407504 0.188372 1.311262
2009-03-06 06:29:59 0.272883 0.817179 0.584664
2009-03-07 06:29:59 -1.767227 1.168876 0.443096
2009-03-08 06:29:59 -0.685501 -0.534373 -0.063906
2009-03-09 06:29:59 0.851820 0.068740 0.566537
2009-03-10 06:29:59 0.390678 -0.012422 -0.152375
2009-03-11 06:29:59 -0.985585 -0.917705 -0.585091
2009-03-12 06:29:59 0.067498 -0.764343 0.497270
mask_panel(pn, msk)
print pn['close']
Out[34]:
ticker AAPL GOOG GS
2009-03-01 06:29:59 -0.082203 -0.286354 NaN
2009-03-02 06:29:59 NaN -0.688933 -1.505137
2009-03-03 06:29:59 -0.525567 NaN -0.035047
2009-03-04 06:29:59 -0.123549 -0.841781 -0.616523
2009-03-05 06:29:59 -0.407504 NaN NaN
2009-03-06 06:29:59 NaN NaN NaN
2009-03-07 06:29:59 -1.767227 NaN NaN
2009-03-08 06:29:59 -0.685501 -0.534373 -0.063906
2009-03-09 06:29:59 NaN NaN NaN
2009-03-10 06:29:59 NaN -0.012422 -0.152375
2009-03-11 06:29:59 -0.985585 -0.917705 -0.585091
2009-03-12 06:29:59 NaN -0.764343 NaN
Also die obige Schleife macht den Trick. Ich weiß, dass es einen schnelleren vektorisierten Weg gibt, dies mit dem ndarray zu tun, aber ich habe das noch nicht zusammengefügt. Es scheint auch, dass dies Funktionalität sein sollte, die in die Pandas-Bibliothek eingebaut ist. Wenn es eine Möglichkeit gibt, dies zu tun, die ich vermisse, wären alle Vorschläge sehr willkommen.
Es fühlt sich an wie Sie sollten in der Lage sein, das Boolsche Panel 'pn.gt (0)' zu benutzen ... –
danke Andy, es sei denn, ich liege falsch, ich denke, das würde etwas anderes machen. Das würde jeden DataFrame in meinem Panel nan out machen, wo seine Werte kleiner als 0 sind. Was ich tun möchte, ist nan out jeden DataFrame in meinem Panel, wo 'close' kleiner als 0 ist. Schließen ist wieder ein spezifischer DataFrame in meinem Panel . Ich werde weiterspielen und posten, wenn mir etwas Schöneres einfällt. – granders19
Würde dies nur den engen Datenrahmen (Teil des Panels) beeinflussen? Möchten Sie das im Panel ändern und das andere unverändert lassen? –