如何在ggplot python中使stat_平滑工作?

如何在ggplot python中使stat_平滑工作?,python,plot,ggplot2,pandas,python-ggplot,Python,Plot,Ggplot2,Pandas,Python Ggplot,这是我的密码: import pandas as pd import pandas.io.sql as sqlio from ggplot import * from db import conn sql = "SELECT * FROM history WHERE time > (NOW() - INTERVAL '1 day')::date" df = sqlio.read_frame(sql, conn) conn.close() lng = pd.melt(df[['time'

这是我的密码:

import pandas as pd
import pandas.io.sql as sqlio
from ggplot import *
from db import conn

sql = "SELECT * FROM history WHERE time > (NOW() - INTERVAL '1 day')::date"
df = sqlio.read_frame(sql, conn)
conn.close()

lng = pd.melt(df[['time', 'players', 'servers']], id_vars='time')
plt = ggplot(aes(x='time', y='value', colour='variable'), data=lng) + \
        geom_line() + \
        stat_smooth(colour='red', se=True) + \
        ggtitle('Players and servers online over last 24h') + \
        xlab("Time of the day") + \
        ylab("Amount")
ggsave(filename="day.svg", plot=plt)
这是代码生成的内容:

历史记录表有3列:

  • 时间-日期时间
  • 玩家-整数
  • 服务器-整数

我想要的是在黑色和橙色的上面画两条平滑的红线。不知怎的,stat_smooth根本不起作用。如何使其工作?

应根据以下问题进行修复:


不幸的是,我帮不了你做
ggplot
之类的事情。但是我想你可能想知道,对于熊猫的当前版本,你可以简单地执行pd.read\u sql(sql,conn)。不是很重要,但是很好。我猜这是日期格式不兼容的原因。你能发布一些
lng
dataframe吗?不知何故,代码在Ubuntu服务器上的生产环境中工作,但在Ubuntu的虚拟机中不工作。我不知道发生了什么。自从最初提出这个问题以来,ggplot已经有了很多更新。这仍然是一个问题吗?