pandas.DataFrame.swaplevel#
- DataFrame.swaplevel(i=-2, j=-1, axis=0)[源代码][源代码]#
在
MultiIndex
中交换级别 i 和 j。默认是交换索引的两个最内层级别。
- 参数:
- i, jint 或 str
要交换的索引级别。可以传递级别名称作为字符串。
- 轴{0 或 ‘index’, 1 或 ‘columns’},默认 0
要交换级别的轴。0 或 ‘index’ 表示行方向,1 或 ‘columns’ 表示列方向。
- 返回:
- DataFrame
在 MultiIndex 中交换层级的 DataFrame。
参见
DataFrame.reorder_levels
重新排序 MultiIndex 的层级。
DataFrame.sort_index
排序 MultiIndex。
例子
>>> df = pd.DataFrame( ... {"Grade": ["A", "B", "A", "C"]}, ... index=[ ... ["Final exam", "Final exam", "Coursework", "Coursework"], ... ["History", "Geography", "History", "Geography"], ... ["January", "February", "March", "April"], ... ], ... ) >>> df Grade Final exam History January A Geography February B Coursework History March A Geography April C
在以下示例中,我们将交换索引的级别。在这里,我们将按列交换级别,但级别也可以按行以类似的方式交换。请注意,按列是默认行为。通过不为 i 和 j 提供任何参数,我们交换最后一个和倒数第二个索引。
>>> df.swaplevel() Grade Final exam January History A February Geography B Coursework March History A April Geography C
通过提供一个参数,我们可以选择与最后一个索引交换的索引。例如,我们可以如下将第一个索引与最后一个索引交换。
>>> df.swaplevel(0) Grade January History Final exam A February Geography Final exam B March History Coursework A April Geography Coursework C
我们也可以通过为 i 和 j 提供值来明确地定义我们想要交换的索引。在这里,我们例如交换第一个和第二个索引。
>>> df.swaplevel(0, 1) Grade History Final exam January A Geography Final exam February B History Coursework March A Geography Coursework April C