將資料集從列重塑為行,其中每列代表不同的日期,所需的輸出需要“日期」列和「值」列,使用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
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中文網其他相關文章!