pandas绘图设置背景

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了pandas绘图设置背景相关的知识,希望对你有一定的参考价值。

它一般是在绘图的最开始进行设置的,可以使用screensize(width, height, bg)函数,其中的三个参数分别是画布的宽、高、背景颜色。宽高的单位是像素,如果用小数表示,则是以屏幕宽高的百分比来确定大小的。但是如果只设置画布大小,是没法控制窗口的大小的,窗口大小需要使用setup(width, height, X, Y)函数来进行设置。前两个参数依旧是宽高,后边X和Y是设置窗口坐标的,默认是以窗口中心为坐标原点,X轴水平向右,Y轴垂直向上。窗口和画布的区别是:窗口可以控制显示窗口的大小,而画布是窗口内绘图区的大小,如果画布大小大于窗口,那么窗口上就会出现滚动条。背景颜色有两种表示方式,一种是常见的颜色,直接使用对应的英文描述即可,比如"black"、“white”、“yellow”、“pink”、“blue”、"red"等等。比如我要一张宽和高均为屏幕0.5倍的窗口,背景颜色为绿色: 参考技术A 使用Matplotlib的方法,即plt.subbplots(nrows=2,ncols=2)或plt.subplot(2,2)

  使用tight_layout()自动调整子图间距以免文字重叠

fig,axes = plt.subplots(2,1)
df['score_math'].plot(ax=axes[0])
axes[0].set_title('math score')

df['score_music'].plot(ax=axes[1])
axes[1].set_title('music score')

#自动调整子图间距,以免重叠
plt.tight_layout()

Pandas GroupBy 的绘图结果

【中文标题】Pandas GroupBy 的绘图结果【英文标题】:Plotting results of Pandas GroupBy 【发布时间】:2013-03-06 03:06:37 【问题描述】:

我开始学习 Pandas,并试图找到最 Pythonic(或 Panda-thonic?)的方法来完成某些任务。

假设我们有一个包含 A、B 和 C 列的 DataFrame。

A 列包含布尔值:每一行的 A 值要么为真,要么为假。 B 列有一些我们想要绘制的重要值。

我们想要发现的是 A 设置为 false 的行的 B 值与 A 设置为 true 的行的 B 值之间的细微差别。

换句话说,如何按 A 列的值(真或假)进行分组,然后在同一张图上绘制两组的 B 列值?这两个数据集应该用不同的颜色来区分这些点。


接下来,让我们为这个程序添加另一个功能:在绘图之前,我们要为每一行计算另一个值并将其存储在 D 列中。这个值是在 A 之前的整个五分钟内存储在 B 中的所有数据的平均值记录 - 但我们只包含存储在 A 中的具有相同布尔值的行。

换句话说,如果我有一行 A=Truetime=t,我想计算列 D 的值,它是从时间 t-5 到 @987654324 的所有记录的 B 的平均值@ 具有相同的A=True

在这种情况下,我们如何对 A 的值执行 groupby,然后将此计算应用于每个单独的组,最后绘制两个组的 D 值?

【问题讨论】:

你有一些示例数据框吗?看起来你可以做一些事情,比如将 groupby 对象保存在一个变量中:grouped = df.groupby('A'),然后做一个 for 循环来绘制:for g, d in grouped: plot(d['B'], color=g)。第二个问题或多或少相同,您可以在其中使用 pandas rolling_mean 创建新列 D。 【参考方案1】:

我认为@herrfz 达到了所有的高点。我只是充实细节:

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt

sin = np.sin
cos = np.cos
pi = np.pi
N = 100

x = np.linspace(0, pi, N)
a = sin(x)
b = cos(x)

df = pd.DataFrame(
    'A': [True]*N + [False]*N,
    'B': np.hstack((a,b))
    )

for key, grp in df.groupby(['A']):
    plt.plot(grp['B'], label=key)
    grp['D'] = pd.rolling_mean(grp['B'], window=5)    
    plt.plot(grp['D'], label='rolling (k)'.format(k=key))
plt.legend(loc='best')    
plt.show()

【讨论】:

这太完美了!您能否谈谈如何为 D 列实现更多自定义计算,如果说我想做一些内置“滚动”Pandas 函数未涵盖的专门计算?谢谢。 (@herrfz) rolling_mean 只是many rolling functions in Pandas 之一。要定义自定义滚动函数,请使用rolling_apply。链接页面上有一个示例。 谢谢。我无法将该示例适应我想要完成的任务,所以我在这里问了另一个问题:***.com/questions/15487022/…

以上是关于pandas绘图设置背景的主要内容,如果未能解决你的问题,请参考以下文章

Pandas GroupBy 的绘图结果

Python Pandas 绘图警告

菜鸟求助关于Canvas绘图背景问题。

如何在 Matlab 中为绘图的特定 x 值设置背景颜色?

Python pandas,多行的绘图选项

Pandas_设置单元格条件格式1——指定值字体变色指定值设置背景色