如何将标签添加到特定位置并将值的总和作为图的大小

How to add labels to particular positions and make a sum of values as a size of plot

A pandas DataFrame 包含但不限于以下值:

x      y       z    
Winter Night   2222
Spring Morning 3888
Summer Day     1111
Autumn Evening 2999
...

很抱歉,由于 NDA

,我无法提供完整的数据集

z变量用于计算总和,并将其作为图形上点的大小

def Scatter(x, y, z, colour_data=None):
    f = plt.figure()
    ax.scatter(x, y, s=z)

What I already have

我想把它做成大小不一的16个点。基本上,我想计算两列的总和并制作适当的磅值。

@Sheldore 很好地指出了您的示例中没有足够的代码可供使用,因此以下内容可能不是您要查找的内容。

我将季节和时间名称转换为整数,因为散点图无法绘制 x/y 轴的字符串。

import pandas as pd

df = pd.DataFrame(data={
    'x': ['Winter','Spring','Summer','Autumn'],
    'y': ['Night','Morning','Day','Evening'],
    'z': [2222,3888,1111,2999],
})

# convert 'x' and 'y' strings to int to enable scatter plot

season_map = {
    'Winter': 0,
    'Spring': 1,
    'Summer': 2,
    'Autumn': 3,
}

time_map = {
    'Night': 0,
    'Morning': 1,
    'Day': 2,
    'Evening': 3,
}

df.loc[:,'x_int'] = df.x.map(season_map)
df.loc[:,'y_int'] = df.y.map(time_map)

ax = df.groupby(['x_int','y_int']).z.sum().reset_index()\
    .plot.scatter(x='x_int', y='y_int', s=df['z'])

ax.set_xlabel('X')
ax.set_ylabel('Y')