Mit openpyxl Diagramm einzeichnen

Wenn du dir nicht sicher bist, in welchem der anderen Foren du die Frage stellen sollst, dann bist du hier im Forum für allgemeine Fragen sicher richtig.
Antworten
serki92
User
Beiträge: 6
Registriert: Dienstag 13. November 2018, 08:35

Dienstag 13. November 2018, 08:57

Halli Hallo,

habe mir einen Auswerteprogramm geschrieben, welches meine Messdaten in Excel ausgibt.
Ich würde gerne in einigen Excelsheets mit openpyxl Diagramme einzeichnen.
Die Diagramme sind alle an der richtigen Stelle. Nur mit dem Inhalt habe ich Probleme.
Zur Info ich benutze PyCharm 2018.1.2 / Python 3.6.6 und bin neu Dabei :D
Mein Code:

from openpyxl.chart import LineChart, Reference
.
.
.
if sheet.title == 'Scope' or sheet.title == 'Overview':
data = Reference(ws, min_col=1, min_row=1, max_col=17, max_row=77) <- Hier
chart = LineChart()
chart.add_data(data) <---- Hier
ws.add_chart(chart, "T15")

Ich muss die Spalten C und F ausgeben :D
Ich habe alles probiert klappt irgendwie nicht :S
Würde bei openpyxl bleiben, weil ich alles damit gemacht habe :D

Vielen Dank schonmal
Liebe Grüße

Serki92 :)
serki92
User
Beiträge: 6
Registriert: Dienstag 13. November 2018, 08:35

Dienstag 13. November 2018, 12:33

Habe es geschafft :D Vieleeen DAAAAANK wer sich die mühe gegeben hat :D

Jetzt muss ich nur noch die Achsen formatieren, :D
Liebe Grüße

Serki92 :)
Benutzeravatar
pixewakb
User
Beiträge: 1139
Registriert: Sonntag 24. April 2011, 19:43

Dienstag 13. November 2018, 21:32

Du könntest mal deine Lösung in Codetags einfügen, das könnte für andere auch interessant sein, Codetags wären ohne Leerzeichen, vor dem Code
[ python ]
und nach dem Code
[/ python ]
Danke!.
serki92
User
Beiträge: 6
Registriert: Dienstag 13. November 2018, 08:35

Mittwoch 14. November 2018, 08:58

from openpyxl import Workbook
from openpyxl.chart import ScatterChart, Reference, Series
.
.
.
# Add charts
if sheet.title == 'Scope':
last_row = (len(sheet.entries)+1)
x_values = Reference(ws, min_col=1, min_row=2, max_row=last_row)
# first chart
chart1 = ScatterChart()
chart1.title = "Distance"
chart1.x_axis.title = 'Time in s'
chart1.y_axis.title = 'Y-Axis'
chart1.x_axis.scaling.min = round(ws.cell(row=2, column=1).value, 0)
chart1.x_axis.scaling.max = ws.cell(row=last_row, column=1).value
y_values1 = Reference(ws, min_col=6, min_row=1, max_row=last_row)
series1 = Series(y_values1, x_values, title_from_data=True)
chart1.series.append(series1)
# second chart
chart2 = ScatterChart()
chart2.title = "Existence"
chart2.x_axis.title = 'Time in s'
chart2.y_axis.title = 'Y-Axis'
chart2.x_axis.scaling.min = round(ws.cell(row=2, column=1).value, 0)
chart2.x_axis.scaling.max = ws.cell(row=last_row, column=1).value

for i in (7, 8, 12):
y_values2 = Reference(ws, min_col=i, min_row=1, max_row=last_row)
series2 = Series(y_values2, x_values, title_from_data=True)
chart2.series.append(series2)
ws.add_chart(chart1, "O2")
ws.add_chart(chart2, "O18")

Verbesserungsvorschläge nehme ich dankend an :D
Liebe Grüße

Serki92 :)
serki92
User
Beiträge: 6
Registriert: Dienstag 13. November 2018, 08:35

Mittwoch 14. November 2018, 10:32

Code: Alles auswählen

 
from openpyxl import Workbook
from openpyxl.chart import ScatterChart, Reference, Series
#
#
#
# Add charts
        if sheet.title == 'Scope':
            last_row = (len(sheet.entries)+1)
            x_values = Reference(ws, min_col=1, min_row=2, max_row=last_row)
            # first chart
            chart1 = ScatterChart()
            chart1.title = "Distance"
            chart1.x_axis.title = 'Time in s'
            chart1.y_axis.title = 'Y-Axis'
            chart1.x_axis.scaling.min = round(ws.cell(row=2, column=1).value, 0)
            chart1.x_axis.scaling.max = ws.cell(row=last_row, column=1).value
            y_values1 = Reference(ws, min_col=6, min_row=1, max_row=last_row)
            series1 = Series(y_values1, x_values, title_from_data=True)
            chart1.series.append(series1)
            # second chart
            chart2 = ScatterChart()
            chart2.title = "Existence"
            chart2.x_axis.title = 'Time in s'
            chart2.y_axis.title = 'Y-Axis'
            chart2.x_axis.scaling.min = round(ws.cell(row=2, column=1).value, 0)
            chart2.x_axis.scaling.max = ws.cell(row=last_row, column=1).value

            for i in (7, 8, 12):
                y_values2 = Reference(ws, min_col=i, min_row=1, max_row=last_row)
                series2 = Series(y_values2, x_values, title_from_data=True)
                chart2.series.append(series2)
            ws.add_chart(chart1, "O2")
            ws.add_chart(chart2, "O18")
Liebe Grüße

Serki92 :)
Antworten