Python, проблема получить значение из поля со списком кнопки - PullRequest
0 голосов
/ 25 апреля 2019

Я пытаюсь получить значение текущего выпадающего списка кнопкой и отображать сообщение. Но я делаю что-то неправильно, чтобы правильно принять выбранное значение.

AttributeError: 'SelectDB' object has no attribute 'cmb'

Как мне получить значение в выпадающем списке?

import sqlite3
from tkinter import *
from tkinter import ttk
from tkinter import messagebox

class SelectDB:
    def __init__(self, wind) :
        self.wind = wind
        self.wind.title ('MyApp')
        ttk.Label(self.wind, text="Select you're Database:").grid (row = 0, column = 0)
        ttk.Combobox(self.wind, width="10", values=("Local (sqllite)","MYSQL")).grid (row = 0, column = 1)
        ttk.Button(text="Start", command=self.checkcmbo).grid (row = 1, column = 0)

    def checkcmbo(self):
        if self.cmb.get() == "Local (sqllite)":
            messagebox.showinfo("What user choose", "you choose Local (sqllite)")
        elif self.cmb.get(self) == "MYSQL":
            messagebox.showinfo("What user choose", "you choose MYSQL")
        else:
            messagebox.showinfo("What user choose", "NOTHING")

if __name__ == '__main__':
    wind = Tk()
    application = SelectDB(wind)
    wind.mainloop()

Ответы [ 2 ]

0 голосов
/ 25 апреля 2019

Функции для сетки, упаковки и размещения объекта Entry и всех других виджетов возвращают None .В python, когда вы делаете a (). B (), результатом выражения является то, что возвращает b (), поэтому Entry (...). Grid (...) вернет None.

Youследует разделить это на две строки

    self.cmb = ttk.Combobox(self.wind, width="10", values=("Local (sqllite)","MYSQL"))
    self.cmb.grid (row = 0, column = 1)
class SelectDB:
def __init__(self, wind) :
    self.wind = wind
    self.wind.title ('MyApp')

    ttk.Label(self.wind, text="Select you're Database:").grid (row = 0, column = 0)

    self.cmb = ttk.Combobox(self.wind, width="10", values=("Local (sqllite)","MYSQL"))
    self.cmb.grid (row = 0, column = 1)
    btn = ttk.Button(text="Start", command=self.checkcmbo).grid (row = 1, column = 0)

def checkcmbo(self):
    if self.cmb.get() == "Local (sqllite)":
        messagebox.showinfo("What user choose", "you choose Local (sqllite)")
    elif self.cmb.get() == "MYSQL":
        messagebox.showinfo("What user choose", "you choose MYSQL")
    else:
        messagebox.showinfo("What user choose", "NOTHING")

  if __name__ == '__main__':
      wind = Tk()
      application = SelectDB(wind)
      wind.mainloop()
0 голосов
/ 25 апреля 2019

попробуйте, я внесу некоторые изменения

import sqlite3
from tkinter import *
from tkinter import ttk
from tkinter import messagebox

class SelectDB:
    def __init__(self, wind) :
        self.wind = wind
        self.wind.title ('MyApp')
        ttk.Label(self.wind, text="Select you're Database:").grid (row = 0, column = 0)
        self.cbCombo = ttk.Combobox(self.wind, width="10", values=("Local (sqllite)","MYSQL"))
        self.cbCombo.grid (row = 0, column = 1)
        ttk.Button(text="Start", command=self.checkcmbo).grid (row = 1, column = 0)

    def checkcmbo(self):

        if self.cbCombo.current()!=-1:
            if self.cbCombo.current() ==0:
                msg="You choos sqlite"
            else:
                msg="You choos MYSQL"

            messagebox.showwarning('MyApp',msg,)
        else:
            messagebox.showwarning('MyApp','You must choose something!',)

if __name__ == '__main__':
    wind = Tk()
    application = SelectDB(wind)
    wind.mainloop()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...