Если вы запустите этот код, вы увидите, что в результате появится окно с двумя выпадающими списками и кнопкой. Когда вы выбираете значение из первого выпадающего списка, оно отражается во втором! Эта проблема должна быть решена.
Примечание : для четкого выполнения этого кода необходимо создать таблицу и добавить в нее несколько записей, по меньшей мере, в две строки с двумя столбцами. Так что выпадающие списки могут быть заполнены.
import tkinter as tk
from tkinter import ttk
from tkinter import messagebox
import pandas as pd
import sqlite3
# Creating tkinter window
conn = sqlite3.connect('test.db')
print('Opened Database successfully');
tempAge = []
Salary = []
cursor = conn.execute('''Select * from Company''')
for row in cursor:
tempAge.append(row[2])
Salary.append(row[4])
data_dict = {'name': pd.Series(tempAge), 'age':pd.Series(Salary)}
dframe = pd.DataFrame(data_dict)
window = tk.Tk()
window.title('Combobox')
window.geometry('500x250')
# label text for title
ttk.Label(window, text="GFG Combobox Widget",
background='green', foreground="white",
font=("Times New Roman", 15)).grid(row=0, column=1)
# label
ttk.Label(window, text="Select the Age :",
font=("Times New Roman", 10)).grid(column=0,
row=5, padx=10, pady=25)
# Combobox creation
n = tk.StringVar()
agechoosen = ttk.Combobox(window, width=27, textvariable=n)
salchoosen = ttk.Combobox(window, width=27, textvariable=n)
agechoosen['values'] = (tempAge)
salchoosen['values'] = (Salary)
ageVar=''
salVar=''
def salComboSelect():
if salchoosen.current()==-1:
s=0
else:
salVar = salchoosen.get()
messagebox.showinfo('Message',str(salVar))
def comboselect():
if agechoosen.current()==-1 and salchoosen.current()==-1:
s=0
else:
ageVar=agechoosen.get()
salVar = salchoosen.get()
tempStr = str(ageVar)+" & "+str(salVar)
messagebox.showinfo('Message',str(tempStr))
# print(monthchoosen.current(), monthchoosen.get())
button = ttk.Button(window, text='Submit', command=comboselect, width=20)
ttk.Label(window, text="Select the Age :",
font=("Times New Roman", 10)).grid(column=0,
row=5, padx=10, pady=25)
agechoosen.grid(column=1, row=5)
salchoosen.grid(column=1, row=6)
button.grid(column=1, row=7)
agechoosen.current()
window.mainloop()
Я думаю, что проблема здесь в строках, упомянутых ниже, но я не уверен. Пожалуйста, помогите.
agechoosen['values'] = (tempAge)
salchoosen['values'] = (Salary)
![enter image description here](https://i.stack.imgur.com/xHHU2.jpg)