Форум программистов, компьютерный форум, киберфорум
Python: Tkinter
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/26: Рейтинг темы: голосов - 26, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 31.05.2021
Сообщений: 3

Как считывать значения ComboBox после создания кнопкой

31.05.2021, 19:28. Показов 5550. Ответов 8

Студворк — интернет-сервис помощи студентам
Здравствуйте, подскажите пожалуйста, как получать выбранные значения с нескольких ComboBox, созданных кнопкой? Т.е. после запуска программы нажимаем несколько раз "+" и выбираем нужные значения в созданных ComboBox. После при нажатии "Cоздать" должен создаться массив M с индексами выбранных значений этих Combobox. Заранее благодарю за любую помощь.

Код:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
from tkinter import *
from tkinter import ttk
from tkinter.ttk import Combobox
 
window = Tk()
window.title('ConfigTO')
window_height = 700
window_width = 900
 
 
def clicked_dob_appar():
    global count_dob_appar
 
    def ud_appar():
        global count_dob_appar
        combo_appar_new.destroy()
        btn_ud_appar.destroy()
        count_dob_appar -= 1
 
    count_dob_appar += 1
    combo_appar_new = Combobox(window, width=50)
    combo_appar_new['values'] = ('','Hyundai Electric', 'Siemens',
                             'Schneider Electric', 'General Electric', 'LS Industrial Systems', 'КЭАЗ', 'Контактор',
                             'ABB')
    combo_appar_new.current(0)
    combo_appar_new.grid(column=1, row=7+count_dob_appar)
    btn_ud_appar = Button(window, text="-", command=ud_appar)
    btn_ud_appar.grid(column=2, row=7+count_dob_appar)
 
 
def clicked_sozd_tab():
    global A
    print(count_dob_appar)
    print(M)
 
count_dob_appar = 0
M = [0]
 
btn_dob_appar = Button(window, text="+", command=clicked_dob_appar)
btn_dob_appar.grid(column=2, row=7)
 
btn_sozd_tab = Button(window, text="Создать", command=clicked_sozd_tab)
btn_sozd_tab.grid(column=1, row=51, sticky=W)
 
 
window.mainloop()
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.05.2021, 19:28
Ответы с готовыми решениями:

Несколько Combobox-ов. После выбора значения в одном Combobox-е, оно должно стать недоступным в других
Доброго времени суток. У меня такая проблемка. Имеется 3 combobox'a ,содержащие названия городов, во всех трех одинаковый список. При...

Как сделать чтобы при изменении значения в ComboBox менялись значения в другом Combobox
Имеется 2 элемента ComboBox и мне нужно сделать так, чтобы при изменении в 1-ой боксе, загружались другие значения во 2. Я делаю с...

Как сделать камеру дочерним объектом после создания другого объекта, или отображение сцены после создания самой камеры?
Есть кнопка при нажатии на неё создается куб ( с помощью Instantiate) как сделать камеру дочерним объектом после того как создался куб на...

8
263 / 152 / 33
Регистрация: 29.06.2019
Сообщений: 1,529
02.06.2021, 21:06
Лучший ответ Сообщение было отмечено leogixer как решение

Решение

берите лист (вне функции задайте)
Python
1
2
3
listNames= ['','Hyundai Electric', 'Siemens',
            'Schneider Electric', 'General Electric', 'LS Industrial Systems', 'КЭАЗ', 'Контактор',
            'ABB']
в #22 combo_appar_new['values'] = listNames
из листа можно получить индекс - так - listNames.index("Siemens")
... а уже как собрать коллекцию значений комбобоксов (из которых вы хотите получить их индексы в нач. последовательности) - это др. вопрос:
см. ваш window.children коллекцию -- пробегите по ней и считайте из каждого Combobox (проверяя pseudocode: if type is Combobox) его StringVar().get(), после чего и вытягивайте индекс из вашего листа
1
263 / 152 / 33
Регистрация: 29.06.2019
Сообщений: 1,529
03.06.2021, 19:42
Лучший ответ Сообщение было отмечено leogixer как решение

Решение

реализация в вашем коде примерно так (строки #33-47):
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
from tkinter import *
from tkinter import ttk
from tkinter.ttk import Combobox
 
window = Tk()
window.title('ConfigTO')
window_height = 700
window_width = 900
 
listNames= ['','Hyundai Electric', 'Siemens',
            'Schneider Electric', 'General Electric', 'LS Industrial Systems', 'КЭАЗ', 'Контактор',
            'ABB']
 
def clicked_dob_appar():
    global count_dob_appar
 
    def ud_appar():
        global count_dob_appar
        combo_appar_new.destroy()
        btn_ud_appar.destroy()
        count_dob_appar -= 1
 
    count_dob_appar += 1
    combo_appar_new = Combobox(window, width=50)
    combo_appar_new['values'] = listNames
    combo_appar_new.current(0)
    combo_appar_new.grid(column=1, row=7+count_dob_appar)
    btn_ud_appar = Button(window, text="-", command=ud_appar)
    btn_ud_appar.grid(column=2, row=7+count_dob_appar)
 
 
count_dob_appar = 0
M = []
 
def clicked_sozd_tab():
        global A
        print(count_dob_appar)
        print(M)
 
        iterable=window.winfo_children()
        #print(iterable)
        for widget in iterable:
            if isinstance(widget, ttk.Combobox):
                print(widget.get())
                M.append(listNames.index(widget.get()))
 
        print(M)
 
 
btn_dob_appar = Button(window, text="+", command=clicked_dob_appar)
btn_dob_appar.grid(column=2, row=7)
 
btn_sozd_tab = Button(window, text="Создать", command=clicked_sozd_tab)
btn_sozd_tab.grid(column=1, row=51, sticky=W)
 
 
window.mainloop()
p.s.
только я бы всё равно все эти функции обернула бы ещё в класс, например, Application... пришлось в параметры класса добавлять "self"
класс:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
from tkinter import Tk, ttk
from tkinter.ttk import Combobox, Button
from tkinter.messagebox import showinfo
 
 
class Application:
 
    def __init__(self, parent):
        self.count_dob_appar= 0
        self.M = []
        self.listNames= ['','Hyundai Electric', 'Siemens',
                    'Schneider Electric', 'General Electric', 'LS Industrial Systems', 'КЭАЗ', 'Контактор',
                    'ABB']
 
        self.parent = parent
        self.add_combo()
 
        btn_dob_appar = Button(window, text="+", command=self.add_combo)
        btn_dob_appar.grid(column=2, row=7)
 
        btn_sozd_tab = Button(window, text="Создать", command=self.clicked_sozd_tab)
        btn_sozd_tab.grid(column=1, row=51, sticky='w')
 
    def add_combo(self):
        global count_dob_appar
 
        def ud_appar():
            global count_dob_appar
            combo_appar_new.destroy()
            btn_ud_appar.destroy()
            self.count_dob_appar -= 1
 
        self.count_dob_appar += 1
        combo_appar_new = Combobox(self.parent, width=50)
        combo_appar_new['values'] = self.listNames
        combo_appar_new.current(self.count_dob_appar)
 
        combo_appar_new.grid(column=1, row=7+self.count_dob_appar)
        btn_ud_appar = Button(self.parent, text="-", command=ud_appar)
        btn_ud_appar.grid(column=2, row=7+self.count_dob_appar)
 
 
    def clicked_sozd_tab(self):
        #global A
        print(self.count_dob_appar)
        print(self.M)
 
        iterable=self.parent.winfo_children()
        #print(iterable)
        for widget in iterable:
            if isinstance(widget, ttk.Combobox):
                print(widget.get())
                self.M.append(self.listNames.index(widget.get()))
        cnt=", ".join(str(v) for v in self.M)
        showinfo(title='indexes in initial source_list', message=cnt)
        del self.M[:]
        print(self.M)
 
 
if __name__ == '__main__':
    window = Tk()
    window.title('ConfigTO')
    window.minsize(400, 200)
    app = Application(window)
    window.mainloop()

но работает ваше ограничение:
>7 comboboxes не считает- упирается в условие вашего кода - row=7+self.count_dob_appar... имхо... не вникала...

Добавлено через 12 минут
p.p.s.
вообще, конечно, tkinter для Front-End'a (название window я бы заменила на название user - т.е. то, что он вводит)... для работы Back-End'а я бы выделяла отдельные классы... может, это просто привычка с NET MVVM- архитектуры... но всё-таки, структурированный код легче читать, править и дорабатывать
2
0 / 0 / 0
Регистрация: 31.05.2021
Сообщений: 3
04.06.2021, 21:33  [ТС]
Большое спасибо за ответы! Буду пробовать. Я только начинаю осваивать программирование поэтому код не очень хорош. С классами пока плохо дружу. По поводу ограничения (row=7+self.count_dob_appar), дело в том, что код тут неполный и в моем полном коде Combox начинается с 7 строки. Мой код без классов, поэтому длинююющий, поэтому не выложил сюда.

Добавлено через 9 минут
Всё отлично работает!
0
263 / 152 / 33
Регистрация: 29.06.2019
Сообщений: 1,529
05.06.2021, 06:24
Цитата Сообщение от JeyCi Посмотреть сообщение
print(M)
#47 (мой пост ваш код) - глюк форума - затёр 1 строку - посмотрите по примеру из класса - надо добавить в конце
Python
1
del self.M[:]
чтобы ваш M лист при повторном нажатии кнопки формировался с нуля, а не дописывал к предыдущему M... или там сами что-нибудь придумывайте...
(только сейчас заметила)
1
263 / 152 / 33
Регистрация: 29.06.2019
Сообщений: 1,529
06.06.2021, 06:59
Цитата Сообщение от JeyCi Посмотреть сообщение
del M[:]
ой, только БЕЗ self в вашем коде... в смысле добавить
1
0 / 0 / 0
Регистрация: 31.05.2021
Сообщений: 3
09.06.2021, 20:26  [ТС]
Хорошо, главное принцип понятен. Всё работает, спасибо. А не подскажите, где можно найти хорошую и ,главное, понятную инфу по ООП и классам? Трудно доходит, честно говоря
0
 Аватар для Михалыч
1011 / 355 / 59
Регистрация: 28.02.2013
Сообщений: 939
09.06.2021, 22:21
leogixer, посмотрите https://younglinux.info/oopython/course мне зашло по ООП, доступно и не слишком мудрено.
1
263 / 152 / 33
Регистрация: 29.06.2019
Сообщений: 1,529
10.06.2021, 12:13
Лучший ответ Сообщение было отмечено leogixer как решение

Решение

Цитата Сообщение от leogixer Посмотреть сообщение
хорошую и ,главное, понятную инфу по ООП и классам?
главное, чтобы понятен был вам ваш код!.. так и выделяйте в классы сущности, которые имеются в бизнес-логике вашего app'а разрабатываемого... просто чтобы читать и сопровождать и модифицировать код было легче... и чтобы не дублировать код в разных частях проекта...
в ООП определиться всего с 3мя пунктами:
- инкапсуляция
- полиморфизм
- наследование
нужны ли они вам, когда и где вы их захотите использовать... инкапсуляция мне нравится, т.к. упрощает чтение кода (когда возвращаешься к нему черех пол-года)...
всё проще простого: Объект.Свойства.Методы - 3 кита для любого высокоуровневого языка программирования... классы создают объекты, которые наделяете Нужными вам свойствами (поля и переменные) и методами, доступными только из объекта, созданного данным классом (кстати, чтобы создать объект его надо проинициализировать, поэтому важна функция _init)... и всё!
главное: вы сами определяете для себя, какие сущности с какими свойствами/полями и методами вам нужны!.. нужны - от слова удобно... свой комфорт в работе со своим кодом знаете только вы (что вам от него надо)... заворачивать теорией и через "ой, чувствую, что сильно раздуваю код без реальной ценности этого раздувания" - не надо... а иметь в простейшем коде пару классов, которые в main всего парой строк выполнят всю нужную работу, - всегда полезно (чтобы ненужную поднаготную спрятать в класс), а самому из 2х строк main'а понять, что там вы хотели от этого кода...
в общем классы - это всё тот же принцип модульности в программировании, только на уровне абстракций создаваемых (т.е. классов)...
поэтому книжки тут не столь важны, важна практика и своё видение нужных в своём коде сущностей и их реализация, а пример Структуры класса можно брать из любого примера, который подвернётся под руки ... в принципе, я описала (_init, поля, методы) - создаём объект в init и имеем в арсенале у этого объекта весь запас свойств и методов его...
... нет гуру, есть только свои задачи и свой код, что вам там надо решаете только вы, а как вы добьётесь своего комфорта в своём коде -- подсматривать можно на любых примерах (которые нравятся) в сети -- это уже просто технические вопросы (и дело вкуса - профессионального и эстетического )

Добавлено через 5 часов 19 минут
добавлю: (встретился яркий пример - статья и линки из неё, если полистаете)
- пример класс для создания итератора (хотя многие классы, которым надо, уже в себе свой итератор имеют)... и оттуда же линк на генератор - т.е. уже реализованный кем-то класс, работающий в цикле for in, как и рукодельный класс итератор, просто со своей логикой, удобный и избавляющий от необходимости городить свой собственный класс для итерации... а всё началась с простых callback'ов - и способов их усовершенствования...
в общем, для создания удобных абстракций и их использования даже в качестве библиотек (если захочется) - ООП самое то, что надо... но не стоит забывать, что городить классы там, где уже есть достойные им альтернативы не обязательно -- "жирные" классы могут вместо улучшения, ухудшить читаемость кода... хотя польза от инкапсуляции (как одном из вариантов реализации модульности проекта) - бесспорна и очевидна, когда проект начинает разрастаться...
имхо... "всё хорошо в меру и в тему и согласно адекватности" - городить классы, не имея на то оснований - мартышкин труд
3
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.06.2021, 12:13
Помогаю со студенческими работами здесь

Как можно реализовать чтобы после выбора значения combobox оно скрывалось из него?
Как можно реализовать чтобы после выбора значения combobox оно скрывалось из него?:umnik:

Сделать чтобы после выбора значения в ComboBox, колесико мышки скролило форму, а не значения контролла
Есть форма с кучей элементов. Когда делаем выбор, на пример в Комбобоксе, при прокручивании колесика мышки скролит только элементы в...

Как считывать значения с текстового файла?
есть код: import re ex = '''// Это однострочный комментарий a = 2; /* Это уже многострочный комментарий */''' ex =...

Как при выборе значения в combobox изменить значение другого combobox
Добрый день. Есть допустим бд с таблицей в которой есть name И number. Как сделать так, чтобы при выборе имени в комбобоксе во втором...

Как записывать и считывать значения в XML файле
Как записывать и считывать значения в XML файле. Будет использоваться как INI файлы раньше...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере нетипового документа выдачи шин для спецтехники с табличной частью, разработанного в конфигурации КА2. Данные берутся из. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru