搜索

查看: 3080|回复: 11

[Python] Pandas.DataFrame重置Series的索引index(reset_index)

[复制链接]
发表于 2023-5-4 17:21:37 | 显示全部楼层 |阅读模式
Editor 2023-5-4 17:21:37 3080 11 看全部
目录
  • 使用reset_index()将索引重新分配给序列号
  • 基本用法
  • 删除原始索引:参数drop
  • 更改原始对象:参数inplace
  • 使用reset_index()和set_index()将索引更改为另一列(重置)如果使用reset_index()方法,则可以将pandas.DataFrame,pandas.Series的索引索引(行名称,行标签)重新分配为从0开始的序列号(行号)。
    如果将行号用作索引,则通过排序更改行的顺序或删除行并得到缺少的号码时,重新索引会更容易。
    当行名(行标签)用作索引时,它也可用于删除当前索引或恢复数据列。您可以使用set_index()和reset_index()将索引更改(重置)到另一列。
    将描述以下内容。
    使用reset_index()将索引重新分配给序列号
  • 基本用法
  • 删除原始索引:参数drop
  • 更改原始对象:参数inplace
    使用reset_index()和set_index()将索引更改为另一列(重置)
    以下面的数据为例。
    import pandas as pd
    df = pd.read_csv('./data/21/sample_pandas_normal.csv')
    print(df)
    #       name  age state  point
    # 0    Alice   24    NY     64
    # 1      Bob   42    CA     92
    # 2  Charlie   18    CA     70
    # 3     Dave   68    TX     70
    # 4    Ellen   24    CA     88
    # 5    Frank   30    NY     57
    该示例为pandas.DataFrame,但pandas.Series也具有reset_index()。两个参数的用法相同。

    使用reset_index()将索引重新分配给序列号
    使用sort_values()对行进行排序以进行说明。有关排序的详细信息,请参见以下文章。
    pandas.DataFrame,Series排序(sort_values,sort_index)
    df.sort_values('state', inplace=True)
    print(df)
    #       name  age state  point
    # 1      Bob   42    CA     92
    # 2  Charlie   18    CA     70
    # 4    Ellen   24    CA     88
    # 0    Alice   24    NY     64
    # 5    Frank   30    NY     57
    # 3     Dave   68    TX     70

    基本用法
    由于索引已经分散,因此将它们重新分配给从0开始的连续数字。
    如果在不指定任何参数的情况下使用reset_index(),则序列号将成为新索引,而原始索引将保留为新列。
    df_r = df.reset_index()
    print(df_r)
    #    index     name  age state  point
    # 0      1      Bob   42    CA     92
    # 1      2  Charlie   18    CA     70
    # 2      4    Ellen   24    CA     88
    # 3      0    Alice   24    NY     64
    # 4      5    Frank   30    NY     57
    # 5      3     Dave   68    TX     70

    删除原始索引:参数drop
    如果参数drop为True,则原始索引将被删除并且不会保留。
    df_r = df.reset_index(drop=True)
    print(df_r)
    #       name  age state  point
    # 0      Bob   42    CA     92
    # 1  Charlie   18    CA     70
    # 2    Ellen   24    CA     88
    # 3    Alice   24    NY     64
    # 4    Frank   30    NY     57
    # 5     Dave   68    TX     70

    更改原始对象:参数inplace
    默认情况下,原始对象不会更改,并且会返回一个新对象,但是如果inplace参数为True,则会更改原始对象。
    df.reset_index(inplace=True, drop=True)
    print(df)
    #       name  age state  point
    # 0      Bob   42    CA     92
    # 1  Charlie   18    CA     70
    # 2    Ellen   24    CA     88
    # 3    Alice   24    NY     64
    # 4    Frank   30    NY     57
    # 5     Dave   68    TX     70

    使用reset_index()和set_index()将索引更改为另一列(重置)
    如果将行名设置为索引而不是数字。
    df = pd.read_csv('./data/21/sample_pandas_normal.csv', index_col=0)
    print(df)
    #          age state  point
    # name
    # Alice     24    NY     64
    # Bob       42    CA     92
    # Charlie   18    CA     70
    # Dave      68    TX     70
    # Ellen     24    CA     88
    # Frank     30    NY     57
    如果使用reset_index()方法,则将序列号设置为索引,并将原始索引添加到data列。
    df_r = df.reset_index()
    print(df_r)
    #       name  age state  point
    # 0    Alice   24    NY     64
    # 1      Bob   42    CA     92
    # 2  Charlie   18    CA     70
    # 3     Dave   68    TX     70
    # 4    Ellen   24    CA     88
    # 5    Frank   30    NY     57
    如果将set_index()照原样应用于原始DataFrame,则会删除原始索引。
    df_s = df.set_index('state')
    print(df_s)
    #        age  point
    # state            
    # NY      24     64
    # CA      42     92
    # CA      18     70
    # TX      68     70
    # CA      24     88
    # NY      30     57
    如果要将原始索引保留为数据字符串,则可以在reset_index()之后使用set_index()。
    df_rs = df.reset_index().set_index('state')
    print(df_rs)
    #           name  age  point
    # state                     
    # NY       Alice   24     64
    # CA         Bob   42     92
    # CA     Charlie   18     70
    # TX        Dave   68     70
    # CA       Ellen   24     88
    # NY       Frank   30     57
    注意,为方便起见,在此示例中将具有重叠值的列设置为索引,但是如果索引值不重叠(每个值都是唯一的),则更容易选择数据。
    到此这篇关于Pandas.DataFrame重置Series的索引index(reset_index)的文章就介绍到这了,更多相关Pandas.DataFrame重置Series索引内容请搜索知鸟论坛以前的文章或继续浏览下面的相关文章希望大家以后多多支持知鸟论坛
  • 知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-28 18:14:02 | 显示全部楼层
    冀苍鸾 2023-6-28 18:14:02 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-29 14:09:30 | 显示全部楼层
    麻辣鸡翅 2023-6-29 14:09:30 看全部
    楼主太厉害了!楼主,I*老*虎*U!我觉得知鸟论坛真是个好地方!
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-29 14:10:23 | 显示全部楼层
    风来时狂放 2023-6-29 14:10:23 看全部
    感谢楼主的无私分享!要想知鸟论坛好 就靠你我他
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-30 15:25:06 | 显示全部楼层
    123456823 2023-6-30 15:25:06 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-30 16:22:41 | 显示全部楼层
    永远就三年疗 2023-6-30 16:22:41 看全部
    楼主,大恩不言谢了!知鸟论坛是最棒的!
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-30 17:45:12 | 显示全部楼层
    尘埃416 2023-6-30 17:45:12 看全部
    这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-7-3 10:12:13 | 显示全部楼层
    伊索谗言 2023-7-3 10:12:13 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-7-3 17:26:13 | 显示全部楼层
    我的苦恼冉 2023-7-3 17:26:13 看全部
    这东西我收了!谢谢楼主!知鸟论坛真好!
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-7-3 18:17:57 | 显示全部楼层
    塞翁364 2023-7-3 18:17:57 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    • 您可能感兴趣
    点击右侧快捷回复 【请勿灌水】
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则 返回列表

    RSS订阅| SiteMap| 小黑屋| 赞兔论坛
    联系邮箱E-mail:zniao@foxmail.com
    快速回复 返回顶部 返回列表