python获取excel,用PySimpleGUI创建一个界面,通过多个按钮实现输出多个折线图
时间: 2024-05-01 21:19:35 浏览: 91
好的,我会尽力回答您的问题。首先,您可以使用Python中的openpyxl库来获取Excel数据,并且可以使用Matplotlib库来创建折线图。然后,您可以使用PySimpleGUI库来创建一个交互式的GUI界面,并通过多个按钮实现输出多个折线图的功能。下面是一个参考的代码示例:
```python
import openpyxl
import matplotlib.pyplot as plt
import PySimpleGUI as sg
# 获取Excel数据
wb = openpyxl.load_workbook('filename.xlsx')
ws = wb.active
data = []
for row in ws.iter_rows(min_row=2, values_only=True):
data.append(row)
# 创建GUI界面
layout = [
[sg.Button('Line Chart 1'), sg.Button('Line Chart 2')],
[sg.Graph((500, 500), (0, 0), (500, 500), key='graph')]
]
window = sg.Window('Excel Data Graphs', layout)
while True:
event, values = window.read()
if event == sg.WINDOW_CLOSED:
break
if event == 'Line Chart 1':
# 绘制折线图1
x_values = range(len(data))
y_values = [row[0] for row in data]
plt.plot(x_values, y_values)
# 更新GUI图形
fig = plt.gcf()
fig.canvas.draw()
img = fig.canvas.tostring_rgb()
window['graph'].draw_image(img, location=(0, 500))
elif event == 'Line Chart 2':
# 绘制折线图2
x_values = range(len(data))
y_values = [row[1] for row in data]
plt.plot(x_values, y_values)
# 更新GUI图形
fig = plt.gcf()
fig.canvas.draw()
img = fig.canvas.tostring_rgb()
window['graph'].draw_image(img, location=(0, 500))
plt.clf()
window.close()
```
这段代码可以创建一个GUI界面,包含两个按钮,分别对应输出两个折线图。每次点击按钮时,程序会根据Excel数据绘制对应的折线图,并在GUI图形中显示。注意,这里使用了Matplotlib的clf()函数来清除之前的图形,以避免图形重叠。希望这能够帮助您解决问题。
阅读全文