python-pptx 的 xy 散点图不起作用

xy scatter plot with python-pptx not working

我正在尝试用 x 和 y 系列数据制作一个简单的 python-pptx xy 散点图,但到目前为止还没有成功。

from pptx import Presentation
from pptx.util import Inches,Pt

from pptx.enum.chart import XL_CHART_TYPE
from pptx.chart.data import XySeriesData

prs = Presentation()
title_slide_layout = prs.slide_layouts[0]
blank_slide_layout = prs.slide_layouts[6]

slide = prs.slides.add_slide(title_slide_layout)
slide2 = prs.slides.add_slide(blank_slide_layout)

title = slide.shapes.title
subtitle = slide.placeholders[1]

title.text = "Hello, World!"
subtitle.text = "python-pptx was here!"
chart_data = XySeriesData
chart_data.x_values=[0,1,2,3,4,5]
chart_data.y_values=[10,22,33,38,40,43]
x, y, cx, cy = Inches(1), Inches(2), Inches(8), Inches(3)
chart = slide2.shapes.add_chart(XL_CHART_TYPE.XY_SCATTER, x, y, cx, cy, chart_data).chart

prs.save('test1.pptx')

我得到的错误是

文件 "C:\Users\adnan\Google Drive\Learning\Pythong_tti_parser\untitled0.py",第 31 行,在 图表 = slide2.shapes.add_chart(XL_CHART_TYPE.XY_SCATTER, x, y, cx, cy, chart_data).图表

文件 "C:\ProgramData\Anaconda3\lib\site-packages\pptx\shapes\shapetree.py",第 250 行,在 add_chart rId = self.part.add_chart_part(chart_type, chart_data)

文件 "C:\ProgramData\Anaconda3\lib\site-packages\pptx\parts\slide.py",第 174 行,在 add_chart_part chart_part = ChartPart.new(chart_type, chart_data, self.package)

文件 "C:\ProgramData\Anaconda3\lib\site-packages\pptx\parts\chart.py",第 30 行,新 chart_blob = chart_data.xml_bytes(chart_type)

AttributeError: 类型对象 'XySeriesData' 没有属性 'xml_bytes'

我今天也在做这个 - 看起来你跳过了一些步骤。

确保您有正确的导入,包括:

from pptx.chart.data import XySeriesData, XyChartData

更改此行:

chart_data = XySeriesData

实例化 class XyChartData:

chart_data = XyChartData()

然后你需要添加一个系列(它创建 XySeries 对象),给它一个名称和一个数字格式(我正在使用 None)

chart_data.add_series('name_of_series', number_format= None)

然后

chart_data.x_values=[0,1,2,3,4,5]
chart_data.y_values=[10,22,33,38,40,43]

我不确定这是否能解决您的问题,但希望对您有所帮助。我今天能够以这种方式替换散点图中的数据。

编辑:

在 chart_data 对象上设置 x_values 和 y_values 一直不一致且不可靠。在下面的示例中,将您的数字列表设置为变量名称。为了清楚起见,我使用 x_values_list 和 y_values_list。

新方法:

将您的 add_series 对象保存到一个变量中,并分别添加 x 和 y 数据点。

chart_data = XyChartData()    
cd = chart_data.add_series('name_of_series', number_format= None)
    for x, y in list(zip(x_values_list, y_values_list)):
         cd.add_data_point(x, y, number_format=None)

此时,chart_data包含了你的系列对象,可以插入到图表形状中,而cd代表XySeries对象。我认为 x_values 和 y_values 可能更像是访问者而不是作者?我无法在 XySeries 级别成功设置这些值。我在尝试将列表设置为 XyChartData 级别的那些属性时遇到了很多问题。这运行得更好。