首页 > 后端开发 > Python教程 > 如何将 Pandas DataFrame 列转换为具有'日期”和'值”列的行?

如何将 Pandas DataFrame 列转换为具有'日期”和'值”列的行?

Patricia Arquette
发布: 2024-12-30 09:07:11
原创
604 人浏览过

How to Transform Pandas DataFrame Columns into Rows with a

使用 Pandas 将列转换为行

将数据集从列重塑为行,其中每列代表不同的日期,并且所需的输出需要“日期”列和“值”列,使用 Pandas 熔体

解法:

df.melt(id_vars=["location", "name"],
        var_name="Date",
        value_name="Value")
登录后复制

示例:

import pandas as pd

df = pd.DataFrame(
    {
        "location": ["A", "B"],
        "name": ["test", "foo"],
        "Jan-2010": [12, 18],
        "Feb-2010": [20, 20],
        "March-2010": [30, 25],
    }
)

result = df.melt(id_vars=["location", "name"],
                  var_name="Date",
                  value_name="Value")

print(result)
登录后复制

输出:

  location  name        Date  Value
0        A  test    Jan-2010     12
1        B   foo    Jan-2010     18
2        A  test    Feb-2010     20
3        B   foo    Feb-2010     20
4        A  test  March-2010     30
5        B   foo  March-2010     25
登录后复制

对于旧版本的 Pandas (
df2 = pd.melt(df,
                  id_vars=["location", "name"], 
                  var_name="Date",
                  value_name="Value")

df2 = df2.sort(["location", "name"])

# Optionally, reset the index
# df2 = df2.reset_index(drop=True)
登录后复制

此代码将按“位置”和“名称”对输出进行排序,并提供没有索引的干净输出。

注意: 在较新版本的 Pandas 中,使用 sort_values 而不是排序。

以上是如何将 Pandas DataFrame 列转换为具有'日期”和'值”列的行?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板