0

'time'「時間」と呼ばれる列の 1 つを含む numpy 構造化配列があります。列が特定の範囲内にあるデータを制限したいと考えています。私はこれを試しました:

time_restricted_data = Data[ (Data['time'] > 0.6) & (Data['time'] < 0.7) ]

しかし、それはすべてのデータを返しましたData['time'] > 0.6.

助言がありますか?

4

1 に答える 1

1

あなたの例には何か問題があります。つまり、確認できません。あなたが書いたものは期待どおりに機能するはずです。

In [19]: Data = np.zeros(100,dtype=[('time', np.float), ('y',np.float)])

In [20]: Data['y'] = np.random.uniform(size=100)

In [21]: Data['time'] = np.random.uniform(size=100)

In [22]: print Data[ (Data['time'] > 0.6) & (Data['time'] < 0.7) ]
[(0.6309334093696576, 0.5898588768194092)
 (0.6026040512366535, 0.4260650141076221)
 (0.6587399844526572, 0.033397798015253444)
 (0.6863639946779522, 0.67002523603246)
 (0.6522035987367735, 0.948019085443445)
 (0.6809894254849801, 0.5131390279565994)
 (0.6311277013562147, 0.5746610745753917)
 (0.6324174554481182, 0.8587836614681397)
 (0.6542221804687635, 0.9706926940115863)
 (0.671321726341415, 0.7446681474117195)]
于 2012-05-01T15:29:43.133 に答える