【问题标题】:Plot dataframe with years in columns with pandas用熊猫在列中绘制带有年份的数据框
【发布时间】:2015-05-27 14:03:59
【问题描述】:

我有一个看起来像这样的数据框:

country,2010,2011,2012
Afghanistan,1,2,3
Belize,5,3,2
England,3,3,4

我想绘制这个数据框,以便在折线图中用一条线表示每个国家/地区,其中 x 轴代表年份。

我该怎么做?

【问题讨论】:

  • df.plot(y = ['2010','2011','2012'], x='country') 做你想做的事吗?
  • 很遗憾没有。这实际上返回了一个相当奇怪的结果
  • 你能发布你的情节应该是什么样子吗,谢谢
  • 它应该只是按年份绘制每个国家/地区的值。像这张图:investing.curiouscatblog.net/wp-content/uploads/2010/06/…
  • 好的,但在那个例子中,顺便说一下,年份是 x 轴

标签: python-2.7 pandas ipython-notebook


【解决方案1】:

我认为您可能需要重塑数据框:

%matplotlib inline
from io import StringIO
import pandas as pd
import matplotlib as mpl
mpl.rc("figure", figsize=(8,6))

data = """
country,2010,2011,2012
Afghanistan,1,2,3
Belize,5,3,2
England,3,3,4
"""

df = pd.read_csv(StringIO(data))
reshaped_df = pd.melt(df, id_vars=["country"], var_name="year")
df = reshaped_df.pivot(index='year', columns='country', values='value')

df.plot()

【讨论】:

  • 纯真棒。谢谢!
猜你喜欢
  • 2017-05-28
  • 2017-09-26
  • 2017-06-09
  • 1970-01-01
  • 2022-01-08
  • 1970-01-01
  • 2015-03-30
  • 2022-11-27
  • 2016-01-07
相关资源
最近更新 更多