繁体   English   中英

Pandas / Python / Matplotlib散点图标记的颜色取决于单元格中的值

[英]Pandas/Python/Matplotlib scatter plot markers colour depending on a value from a cell

我一直在寻找有关如何根据“第三”列的值在散点图上设置点的解决方案。 我找不到任何现成的解决方案,因此我已经构建了自己的解决方案,我想与他人分享(也许有人会使用它):)如果这不是发布它的地方,那么我很抱歉并请删除它。

假设存在如下数据帧“ scatterData”:

    lad2014_name    Male    Female  Result
0   ABERDEEN CITY   95154   97421   -21.78
1   ABERDEENSHIRE   101875  105141  -13.10
2   ADUR    24047   26574   -16.16
3   ALLERDALE       38346   40192   -44.56
.
.
.
499 AMBER VALLEY    48720   51502   -3.56

我想在散点图上绘制男性和女性,但是我也想通过更改标记的颜色来显示“结果”是负数还是正数。 所以我做到了:

def resultColour(z):
    colour = '#e31a1c'
    if z > 0:
        colour = '#1f78b4'
    return colour

#Plotting the scatter plot
plt.figure(figsize=(12,10))

for index, row in scatterData.iterrows(): 
    x = row.Male
    z = row.Result
    y = row.Female
    t = resultColour(z)
    plt.scatter(x, y, c=t,s=85)
plt.xlabel('X axis lable',fontsize=15)
plt.ylabel('Y axis lable',fontsize=15)

plt.title('Plot title',fontsize=18)

plt.plot()

产生如下散点图

散点图

实际上,您可以在plt.scatterc关键字参数提供值的数组。 它们将根据您可以使用cmap关键字设置的颜色图映射到标记颜色。

例:

import pandas as pd
import numpy as np
from matplotlib import pyplot as plt
from matplotlib import cm

np.random.seed(0)
df = pd.DataFrame({'x':np.random.randint(0,10,size=20),
                   'y':np.random.randint(0,10,size=20),
                   'z':np.random.uniform(-1,1,size=20)})

plt.figure(figsize=(5,5))
plt.scatter(df.x, df.y, c = df.z>0, cmap = cm.RdYlGn)

产生

彩色散点图

cm模块具有多种颜色表 如果您需要自己的确切颜色,则可以使用列出的颜色表,如下所示:

cmap = matplotlib.colors.ListedColormap(['#e31a1c','#1f78b4'])
plt.scatter(df.x, df.y, c = df.z>0, cmap = cmap)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM