ここに私のコードがあります:
import pandas as pd
data = pd.DataFrame({'Odd':[1,3,5,6,7,9], 'Even':[0,2,4,6,8,10]})
for i in reversed(data):
print(data['Odd'], data['Even'])
このコードを実行すると、次のエラーが表示されます。
Traceback (most recent call last):
File "C:\Python33\lib\site-packages\pandas\core\generic.py", line 665, in _get_item_cache
return cache[item]
KeyError: 5
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "C:\Users\*****\Documents\******\********\****.py", line 5, in <module>
for i in reversed(data):
File "C:\Python33\lib\site-packages\pandas\core\frame.py", line 2003, in __getitem__
return self._get_item_cache(key)
File "C:\Python33\lib\site-packages\pandas\core\generic.py", line 667, in _get_item_cache
values = self._data.get(item)
File "C:\Python33\lib\site-packages\pandas\core\internals.py", line 1656, in get
_, block = self._find_block(item)
File "C:\Python33\lib\site-packages\pandas\core\internals.py", line 1936, in _find_block
self._check_have(item)
File "C:\Python33\lib\site-packages\pandas\core\internals.py", line 1943, in _check_have
raise KeyError('no item named %s' % com.pprint_thing(item))
KeyError: 'no item named 5'
なぜこのエラーが発生するのですか?
どうすれば修正できますか?pandas.DataFrame
を逆にする正しい方法は何ですか?
data.reindex(index=data.index[::-1])
または単に:
data.iloc[::-1]
ダウンからアップまでのfor
ループが必要な場合は、データフレームを反転します。
for idx in reversed(data.index):
print(idx, data.loc[idx, 'Even'], data.loc[idx, 'Odd'])
または
for idx in reversed(data.index):
print(idx, data.Even[idx], data.Odd[idx])
reversed
が最初にdata.__len__()
を呼び出して6を返すため、エラーが発生します。その後、range(6, 0, -1)
のj
に対してdata[j - 1]
を呼び出し、最初の呼び出しがbe data[5]
;ただし、pandasデータフレームdata[5]
では列5を意味し、列5がないため、例外がスローされます。 ( docs を参照)
さらに簡単な方法で行を反転できます。
df[::-1]