I need to make a chart in PowerPoint. But I can't make it colorful. For example, the number 1 should be red, the number 2 - is blue, the number of 3 - green, depending on the parameter, which is set previously. Use Python-pptx. Please tell me how to solve the problem.
My code:
# -*- coding: utf-8 -*-
from pptx import Presentation
from pptx.enum.chart import XL_CHART_TYPE
from pptx.chart.data import ChartData
from pptx.util import Inches
from pptx.enum.chart import XL_TICK_MARK
from pptx.util import Pt
from pptx.dml import line
from pptx.enum.chart import XL_TICK_LABEL_POSITION
from pptx.dml.color import RGBColor
from pptx.enum.chart import XL_LABEL_POSITION
#if a>50: color='green'
#if a>20 and a<50: color='blue'
#if a<20: color='red'
#if b>50: color='green'
#if b>20 and b<50: color='blue'
#if b<20: color='red'
#if c>50: color='green'
#if c>20 and c<50: color='blue'
#if c<20: color='red'
a=70
b=30
c=40
# create presentation with 1 slide ——
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts)
# define chart data ———————
chart_data = ChartData()
chart_data.categories =
chart_data.add_series('',(a,b,c))
# add chart to slide ——————–
x, y, cx, cy = Inches(1), Inches(2), Inches(3), Inches(3)
graphic_frame = slide.shapes.add_chart(
XL_CHART_TYPE.BAR_CLUSTERED, x, y, cx, cy, chart_data
)
chart = graphic_frame.chart
category_axis = chart.category_axis
category_axis.visible = False
category_axis.has_major_gridlines = False
category_axis.has_minor_gridlines = False
category_axis.major_tick_mark = XL_TICK_MARK.NONE
category_axis.minor_tick_mark = XL_TICK_MARK.NONE
category_axis.tick_labels.font.size = Pt(12)
value_axis = chart.value_axis
value_axis.minimum_scale = 0
value_axis.maximum_scale = None
value_axis.has_major_gridlines = False
value_axis.has_minor_gridlines = False
value_axis.minor_tick_mark = XL_TICK_MARK.NONE
value_axis.major_tick_mark = XL_TICK_MARK.NONE
value_axis.axis_labels = False
value_axis.tick_label_position=XL_TICK_LABEL_POSITION.NONE
value_axis.has_axis_labels=False
tick_labels = value_axis.tick_labels
tick_labels.visible=False
plot = chart.plots
plot.has_data_labels = True
data_labels = plot.data_labels
data_labels.font.size = Pt(13)
data_labels.font.color.rgb = RGBColor(0x0A, 0x42, 0x80)
data_labels.position = XL_LABEL_POSITION.OUTSIDE_END
tick_labels.font.color.rgb=RGBColor(0x0A, 0x42, 0x80)
prs.save('chart-02.pptx')
I use Python 2.7, 32-bit
I know this is an old question, but in case anyone stumbles here like I did. This is how I color charts per different series:
colors = {}
colors['seriesa'] = '3C2F80'
colors['seriesb'] = '3C2F81'
colors['seriesc'] = '3C2F82'
for series in chart.series:
if series.name in colors:
fill = series.format.fill #fill the legend as well
fill.solid()
fill.fore_color.rgb = RGBColor.from_string(colors[series.name])
Here is an approach to color your graphs in python pptx:
Declaring a class will help you to assign multiple colors for your chart
from pptx.dml.color import RGBColor
class ColorCodes:
PRIMARY_COLOR = RGBColor(255, 222, 23)
SECONDARY_COLOR = RBGColor(255,0,0)
#graphic_frame is the variable where shape is assigned
chart = graphic_frame.chart
chart_points = chart.plots[0].series[0].points
accent_colors = [ColorCodes.PRIMARY_COLOR, ColorCodes.SECONDARY_COLOR]
for point, accent_color in zip(chart_points, accent_colors):
fill = point.format.fill
fill.solid()
for i in range(len(accent_colors)):
fill.fore_color.rgb = accent_colors[i]
If you want a static color for all the series you could declare it directly
fill.fore_color.rgb = RGBColor(0,255,255)
If you want predefined colors of python pptx for your charts you could follow the solution provided here: Python pptx custom color for each category
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.