txt ファイルで大きなタブ区切りのデータセットを処理するために、Ubuntu 13.10 の ipython3 で pandas 0.12.0 を使用しています。read_table を使用して txt から DataFrame を作成すると機能するように見え、最初の行はヘッダーとして読み取られますが、その名前をインデックスとして使用して最初の列にアクセスしようとすると、KeyError がスローされます。列名がすべて正しく読み取られているように見え、他のすべての列にこの方法でインデックスを付けることができることを考えると、なぜこれが起こるのかわかりません。
データは次のようになります。
RECORDING_SESSION_LABEL LEFT_GAZE_X LEFT_GAZE_Y RIGHT_GAZE_X RIGHT_GAZE_Y VIDEO_FRAME_INDEX VIDEO_NAME
73_1 . . 395.1 302 . .
73_1 . . 395 301.9 . .
73_1 . . 394.9 301.7 . .
73_1 . . 394.8 301.5 . .
73_1 . . 394.6 301.3 . .
73_1 . . 394.7 300.9 . .
73_1 . . 394.9 301.3 . .
73_1 . . 395.2 302 1 1_1_just_act.avi
73_1 . . 395.3 302.3 1 1_1_just_act.avi
73_1 . . 395.4 301.9 1 1_1_just_act.avi
73_1 . . 395.7 301.5 1 1_1_just_act.avi
73_1 . . 395.9 301.5 1 1_1_just_act.avi
73_1 . . 396 301.5 1 1_1_just_act.avi
73_1 . . 395.9 301.5 1 1_1_just_act.avi
15_1 395.4 301.7 . . . .
区切り文字は間違いなくタブであり、末尾または先頭の空白はありません。
この最小限のプログラムでエラーが発生します。
import pandas as pd
samples = pd.read_table('~/datafile.txt')
print(samples['RECORDING_SESSION_LABEL'])
エラーが発生します:
---------------------------------------------------------------------------
KeyError Traceback (most recent call last)
<ipython-input-65-137d3c16b931> in <module>()
----> 1 print(samples['RECORDING_SESSION_LABEL'])
/usr/lib/python3/dist-packages/pandas/core/frame.py in __getitem__(self, key)
2001 # get column
2002 if self.columns.is_unique:
-> 2003 return self._get_item_cache(key)
2004
2005 # duplicate columns
/usr/lib/python3/dist-packages/pandas/core/generic.py in _get_item_cache(self, item)
665 return cache[item]
666 except Exception:
--> 667 values = self._data.get(item)
668 res = self._box_item_values(item, values)
669 cache[item] = res
/usr/lib/python3/dist-packages/pandas/core/internals.py in get(self, item)
1654 def get(self, item):
1655 if self.items.is_unique:
-> 1656 _, block = self._find_block(item)
1657 return block.get(item)
1658 else:
/usr/lib/python3/dist-packages/pandas/core/internals.py in _find_block(self, item)
1934
1935 def _find_block(self, item):
-> 1936 self._check_have(item)
1937 for i, block in enumerate(self.blocks):
1938 if item in block:
/usr/lib/python3/dist-packages/pandas/core/internals.py in _check_have(self, item)
1941 def _check_have(self, item):
1942 if item not in self.items:
-> 1943 raise KeyError('no item named %s' % com.pprint_thing(item))
1944
1945 def reindex_axis(self, new_axis, method=None, axis=0, copy=True):
KeyError: 'no item named RECORDING_SESSION_LABEL'
単純に実行print(samples)
すると、最初の列とそのヘッダーを含むテーブル全体を印刷するという期待される出力が得られます。他の列を印刷しようとすると (つまり、まったく同じコードですが、「RECORDING_SESSION_LABEL」が「LEFT_GAZE_X」に置き換えられています)、正常に機能します。さらに、ヘッダーは正しく読み込まれたようで、pandas は「RECORDING_SESSION_LABEL」をカラム名として認識します。これは、読み込まれた後に .info() メソッドを使用し、サンプルの .columns 属性を表示することで証明されます。
>samples.info()
<class 'pandas.core.frame.DataFrame'>
Int64Index: 28 entries, 0 to 27
Data columns (total 7 columns):
RECORDING_SESSION_LABEL 28 non-null values
LEFT_GAZE_X 28 non-null values
LEFT_GAZE_Y 28 non-null values
RIGHT_GAZE_X 28 non-null values
RIGHT_GAZE_Y 28 non-null values
VIDEO_FRAME_INDEX 28 non-null values
VIDEO_NAME 28 non-null values
dtypes: object(7)
>print(samples.columns)
Index(['RECORDING_SESSION_LABEL', 'LEFT_GAZE_X', 'LEFT_GAZE_Y', 'RIGHT_GAZE_X', 'RIGHT_GAZE_Y', 'VIDEO_FRAME_INDEX', 'VIDEO_NAME'], dtype=object)
私が関連していると思われる別のエラー動作は、ipython のタブ補完を使用しているときに発生します。これにより、属性であるかのようにサンプルの列にアクセスできます。最初の列を除くすべての列で機能します。すなわち; >samples.R
提案のみでタブキーを押しますsamples.RIGHT_GAZE_X samples.RIGHT_GAZE_Y
。
では、データフレーム全体を見ると正常に動作し、その名前を正しく読み取ったように見えても、名前で最初の列にアクセスしようとすると失敗するのはなぜですか?