简体   繁体   中英

Altair - how to show a dataframe column as label with its respective color

I am trying to show on an Area Chart the column name(s) I selected from a Dataframe as label, along with its respective color using Altair.

The problem is that every time I do it, the chart disappear and I can't customize the colors based on a list of hex Codes.

Is there any way to achieve this?

我需要的标签

我需要的定制颜色,可惜没有标签

import altair as alt
import pandas as pd
import os


df = {
    'Month': ['Apr', 'May'],
    'Status': ['Working', 'Complete'],
    'Revenue': [1000, 2000],
    'Profit': [500, 600]
}

df = pd.DataFrame(df)

hexList = [
    '#002664', '#72BF44', '#EED308', '#5E6A71', '#7C9DBE', '#F47920', '#1C536E', '#2D580C',
]

xSelected = 'Status'
ySelected = ['Revenue']

chartsList = []

chart = alt.Chart(df).mark_area().encode(
    x=xSelected,
    y=ySelected[0],
    #color=alt.Color(f'{xSelected}:N'), ### **==> this gives me the labels I neeed, but no chart is plotted**
    color=alt.value(f'{hexList[0]}'), ### **==> this gives me the chart with the color I want, but without the labels I need**
    tooltip=ySelected
)

mainDir = os.path.dirname(__file__)
filePath = os.path.join(mainDir, 'altairChart.html')
chart.save(filePath)

The reason the chart disappears with a color encoding is because your color groups each contain only a single point, and the area under a point has zero width and thus appears empty. Perhaps a bar chart would be a better fit?

chart = alt.Chart(df).mark_bar().encode(
    x=xSelected,
    y=ySelected[0],
    color=alt.Color(f'{xSelected}:N'),
    tooltip=ySelected
)

在此处输入图像描述

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

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