Wprowadzenie
Aspose.Cells FOSS supports creating charts directly inside Excel .xlsx pliki z Python. Biblioteka zapewnia dedykowane add_*() metody dla 16 typów wykresów (Line, Bar, Pie, Area, Scatter, Waterfall, Combo, Stock, Surface, Radar, Treemap, Sunburst, Histogram, Funnel, Box & Whisker i Map). Z nich, Liniowy, słupkowy, kołowy, obszarowy i giełdowy mają pełne wsparcie serializacji XML i zapisują się poprawnie do .xlsx. Pozostałe typy mogą być tworzone w pamięci, ale mogą nie zachować całego formatowania po zapisaniu.
Wykresy są dodawane za pomocą worksheet.charts.add_*() metody, które przyjmują ramkę ograniczającą zdefiniowaną przez (upper_left_row, upper_left_column, lower_right_row, lower_right_column) jako indeksy zerowe. Dane serii są dodawane za pomocą chart.n_series.add().
Tworzenie wykresu słupkowego
from aspose.cells_foss import Workbook
workbook = Workbook()
worksheet = workbook.worksheets[0]
# Write data
months = ["Jan", "Feb", "Mar", "Apr", "May", "Jun"]
sales = [100, 150, 120, 180, 200, 170]
for i, (m, s) in enumerate(zip(months, sales), 2):
worksheet.cells[f"A{i}"].value = m
worksheet.cells[f"B{i}"].value = s
# Add a bar chart anchored to rows 0-20, columns 4-12
chart = worksheet.charts.add_bar(0, 4, 20, 12)
chart.title = "Monthly Sales"
chart.n_series.add("B2:B7", category_data="A2:A7", name="Sales")
workbook.save("bar_chart.xlsx")
Tworzenie wykresu liniowego
from aspose.cells_foss import Workbook
workbook = Workbook()
worksheet = workbook.worksheets[0]
months = ["Jan", "Feb", "Mar", "Apr", "May", "Jun"]
sales = [100, 150, 120, 180, 200, 170]
for i, (m, s) in enumerate(zip(months, sales), 2):
worksheet.cells[f"A{i}"].value = m
worksheet.cells[f"B{i}"].value = s
# Line chart anchored to rows 0-20, columns 4-12
chart = worksheet.charts.add_line(0, 4, 20, 12)
chart.title = "Monthly Sales"
chart.n_series.add("B2:B7", category_data="A2:A7", name="Sales")
workbook.save("line_chart.xlsx")
Kluczowe cechy
- 16 chart creation methods available; Liniowy, słupkowy, kołowy, obszarowy i giełdowy mają pełne wsparcie zapisu — inne typy mogą być tworzone, ale mogą nie serializować całego formatowania do
.xlsx - Wykresy są pozycjonowane przy użyciu prostokąta ograniczającego o indeksach zerowych wierszy i kolumn
- Dane serii i etykiety kategorii są określane przy użyciu ciągów zakresów w stylu Excela (
"B2:B7") - Nie wymaga Microsoft Excel, automatyzacji COM ani natywnych zależności