我希望制作一个分面网格,列为变量名称,行为部门,每个小图表都是y=value和x=date的散点图。
我的数据类似于这样:
我想制作一个多面板网格图,变量名为列,部门为行,每个小图表都是y=value和x=date的散点图。
这是我目前拥有的。它几乎可以工作,但我想看到不被挤在一起的底部日期,所以我想看到“3/1 4/1 5/1”而不是完整的日期。但我无法弄清楚如何进行格式化。
我的数据类似于这样:
import pandas as pd
import numpy as np
import seaborn as sns
import matplotlib.pyplot as plt
from datetime import datetime
import matplotlib.dates as mdates
import random
datelist = pd.date_range(start="march 1 2020", end="may 20 2020", freq="w").tolist()
varlist = ["x", "y", "z", "x", "y", "z", "x", "y", "z", "x", "y", "z"]
deptlist = ["a", "a", "b", "a", "a", "b", "a", "a", "b", "a", "a", "b"]
vallist = random.sample(range(10, 30), 12)
df = pd.DataFrame({'date': datelist, 'value': vallist, 'variable': varlist, 'department': deptlist})
我想制作一个多面板网格图,变量名为列,部门为行,每个小图表都是y=value和x=date的散点图。
这是我目前拥有的。它几乎可以工作,但我想看到不被挤在一起的底部日期,所以我想看到“3/1 4/1 5/1”而不是完整的日期。但我无法弄清楚如何进行格式化。
plt.style.use('seaborn-darkgrid')
xformatter = mdates.DateFormatter("%m-%d")
g = sns.FacetGrid(df2, row="department", col="variable", sharey='row')
g = g.map(plt.plot, "date", "value", marker='o', markersize=0.7)
datelist = pd.date_range(start="march 1 2020", end="june 1 2020", freq="MS").tolist()
g.set(xticks=datelist)
这很接近了,但请注意底部x轴上的日期。它们都挤在一起了。这就是为什么我尝试使用特殊的日期格式化程序,但无法使其工作的原因。实际上,我希望每个日期显示为“月-日”,并且我可以控制出现的刻度标记数量。