python - 如何从 tkinter 中的 excel 值中下拉?
问题描述
from openpyxl import load_workbook
wb = load_workbook(filename=r'C:\Users\Hp\Desktop\Test data.xlsx' )
ws = wb['Sheet1']
range=ws['B2':'B10']
for cell in range:
for x in cell:
y=x.value
print(y)
win=Tk()
clicked=StringVar()
combodata=ttk.Combobox(win, width=100,state='readonly')
combodata['values']=[(y)]
combodata.pack(pady=20)
win.mainloop()
我准备了这段代码。这会打印列中的所有值,但是当涉及到 tkinter-dropdown 时,它只提供所提供范围内的最后一个值的选项,即仅 B10。你们中的任何人都可以根据我的需要修改此代码吗?我在列中有超过 1000 个值。提前致谢。
解决方案
创建一个空列表,然后在列中附加每个值。此外,请确保不要将保留关键字用作变量。
代码:
from openpyxl import load_workbook
from tkinter import *
import tkinter.ttk as ttk
# Load the xlsx file, then store the value of each column in the "elements" list
wb = load_workbook(filename=r"C:\Users\Hp\Desktop\Test data.xlsx")
ws = wb['Sheet1']
xlsx_range = ws['B2':'B10']
elements = []
for cell in xlsx_range:
for x in cell:
y = x.value
elements.append(y)
print(y)
# Tkinter stuff
win = Tk()
clicked = StringVar()
combodata = ttk.Combobox(win, width=100,state='readonly', values=elements)
combodata.pack(pady=20)
win.mainloop()
推荐阅读
- angular - JSON.stringify(input) 返回未定义
- c# - Caliburn NotifyOfPropertyChanged:System.InvalidCastException
- php - 在 Wordpress 中保护自定义 rest api 端点的正确方法是什么?
- c# - 如何为选项卡项的标题设置样式?
- css - 如何在 AdminLTE 中将侧边栏移动到仪表板的右侧?
- java - 类treenode中的构造函数treenode不能应用于java中的给定类型?
- vue.js - 输入带有当前日期的日期占位符
- c# - 如何从工具窗口访问当前代码编辑器?
- email - 如何使用 Outlook 的 SMTP 服务器发送电子邮件?
- android - BufferQueueProducer 问题专门针对 Android Q Pixel 3 和 3 XL 设备。模拟器工作正常