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 级别的那些属性时遇到了很多问题。这运行得更好。
我正在尝试用 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 级别的那些属性时遇到了很多问题。这运行得更好。