Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Matplotlib different colors for bar graph based on value

I'm plotting returns for sectors and all the stocks in them. I would like to have the values > 100 to be green, and < 100 to be red. Here's my code:

sector_lst = ['XLK','XLF','XLE']  ## etc.

for i in sector_lst:                   
    fig = plt.figure(figsize=(12, 8)) 

    for x in sectordict[i]:                #sectordict[i] is all the stocks in a sector (so AAPL, GOOG, etc. for tech) 
        if pct_change[x] > 1:              
             pct_change[sectordict[i]].plot(kind='bar',color='g') 

        ##if pct_chg < 1
        else:                              
             pct_change[sectordict[i]].plot(kind='bar',color='r') 


plt.title(i)

So far this is returning the whole sector graphs as green or red; if the first value is > 100 all stocks will be green and vice versa.

My expected output is to have 11 graphs (which it currently does), but with different colors for each stock within the graph, if stock had > 100% return then it shows green and < 100% it shows red.

like image 724
thomas.mac Avatar asked May 05 '26 00:05

thomas.mac


2 Answers

After few tries with Pandas plot() I didn't find a way to achieve what you expect but you can easily do that with Matplotlib directly.

I hope this will help:

I created sample df:

df = pd.DataFrame({'a' : [2,6,2,4,5,3,7]})

and I create two temp df which will store only values satisfying the condition:

t1 = df[df['a']<5]
t2 = df[df['a']>=5]

and then just plot it :

plt.bar(t1.index.values, t1['a'], color='r')
plt.bar(t2.index.values, t2['a'], color='g')

the final result looks like this:

enter image description here

Is that what you expect?

like image 189
Kacper Wolkowski Avatar answered May 07 '26 13:05

Kacper Wolkowski


You can achieve your result in a single call to plt.bar this way:

df = pd.DataFrame({'a' : [2,6,2,4,5,3,7]})
df['colors'] = 'r'
df.loc[df.a>=5,'colors'] = 'g'
plt.bar(df.index, df.a, color=df.colors)

You also mention in a comment that sectordict[i] is a dictionary, but you can easily convert a dictionary into a dataframe with: pd.DataFrame.from_dict.

like image 21
Ramon Crehuet Avatar answered May 07 '26 13:05

Ramon Crehuet



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!