Pandas_[‘index‘]_is_not_found_in_axis

在 pandas 表格操作中,很容易多出一列 ‘index’ 列,drop 也 drop 不掉。

问题:
In pandas, after reset_index(), it emerges a new ‘index’ col, but I don’t want it. When I try df.drop(‘index’, axis=1), it tells me [‘index’] not found in axis. I don’t want this ‘index’ col!

whenever doing:
df = df.reset_index()
df = df.rename(columns={‘xx’: ‘yy’})
df = df.sort_values(by=‘xxx’, ascending=False, inplace=True)
When I enter inplace=True or not, or using df = or not, it will show me a new ‘index’ col that I can’t drop.

建议:

When you use reset_index() in pandas, it adds a new column called index by default, which contains the old index values. If you want to drop this new index column after resetting the index, you should use the drop() method with the inplace=True parameter to modify the DataFrame in place, or you can assign the result to a new variable.

Here’s how you can do it:

import
运行后返回下面的代码,请修改。KeyError Traceback (most recent call last) Cell In[9], line 390 387 print("处理完成!") 389 if __name__ == "__main__": --> 390 main() Cell In[9], line 364, in main() 362 # 确保列顺序正确 363 ordered_columns = ['datetime'] + list(closing_series.keys()) --> 364 final_df = final_df[ordered_columns] 366 # 最终去重(关键修改点) 367 final_df.drop_duplicates(subset=['datetime'], keep='first', inplace=True) File ~\anaconda3\Lib\site-packages\pandas\core\frame.py:4108, in DataFrame.__getitem__(self, key) 4106 if is_iterator(key): 4107 key = list(key) -> 4108 indexer = self.columns._get_indexer_strict(key, "columns")[1] 4110 # take() does not accept boolean indexers 4111 if getattr(indexer, "dtype", None) == bool: File ~\anaconda3\Lib\site-packages\pandas\core\indexes\base.py:6200, in Index._get_indexer_strict(self, key, axis_name) 6197 else: 6198 keyarr, indexer, new_indexer = self._reindex_non_unique(keyarr) -> 6200 self._raise_if_missing(keyarr, indexer, axis_name) 6202 keyarr = self.take(indexer) 6203 if isinstance(key, Index): 6204 # GH 42790 - Preserve name from an Index File ~\anaconda3\Lib\site-packages\pandas\core\indexes\base.py:6252, in Index._raise_if_missing(self, key, indexer, axis_name) 6249 raise KeyError(f"None of [{key}] are in the [{axis_name}]") 6251 not_found = list(ensure_index(key)[missing_mask.nonzero()[0]].unique()) -> 6252 raise KeyError(f"{not_found} not in index") KeyError: "['datetime'] not in index"
最新发布
09-03
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

「已注销」

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值