散点图

散点图或xy图与某些折线图相似。主要的区别在于,一系列值被绘制在另一个值上。在值无序的情况下,这很有用。

from openpyxl import Workbook
from openpyxl.chart import (
    ScatterChart,
    Reference,
    Series,
)

wb = Workbook()
ws = wb.active

rows = [
    ['Size', 'Batch 1', 'Batch 2'],
    [2, 40, 30],
    [3, 40, 25],
    [4, 50, 30],
    [5, 30, 25],
    [6, 25, 35],
    [7, 20, 40],
]

for row in rows:
    ws.append(row)

chart = ScatterChart()
chart.title = "Scatter Chart"
chart.style = 13
chart.x_axis.title = 'Size'
chart.y_axis.title = 'Percentage'

xvalues = Reference(ws, min_col=1, min_row=2, max_row=7)
for i in range(2, 4):
    values = Reference(ws, min_col=i, min_row=1, max_row=7)
    series = Series(values, xvalues, title_from_data=True)
    chart.series.append(series)

ws.add_chart(chart, "A10")

wb.save("scatter.xlsx")
“散点图示例”

注解

规范中说,有以下类型的散点图:“直线”、“线型标记”、“标记”、“平滑”、“平滑标记”。但是,至少在Microsoft Excel中,这只是其他设置的快捷方式,否则将不会产生任何效果。为了与线图一致,应手动设置每个系列的样式。