Форум программистов, компьютерный форум, киберфорум
Python: GUI, графика
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/18: Рейтинг темы: голосов - 18, средняя оценка - 4.72
13 / 10 / 5
Регистрация: 11.10.2019
Сообщений: 290

Возврат значения из функции

02.12.2019, 17:02. Показов 3532. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер. Не могу вернуть значение из функции после connect(сигнала) или не так делаю. И еще хотелось бы после выбора строки чтобы закрывалось это диалоговое окно. Понятно что Dialog.close() но не срабатывает,это наверно потому что отдельные функции,можно сделать глобальным виджет диалог, но это как я понял плохой стиль программирования. Уточню в этом модуле только функции,без классов и прочего. Из другого главного модуля вхожу сюда.Вот хотелось бы после выбора переходим назад на главное окно и знало значение. Скорее всего проблема в получении значения после коннекта.

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
def FASTMENU(**kwargs):
    tek_zag = kwargs.get("zag")
    tek_s = kwargs.get("s")
 
    #Создаем диалоговое окно
    Dialog = QtWidgets.QDialog()
    Dialog.setWindowTitle(tek_zag)
    Dialog.resize(250,100)
    #Оставим только кнопку закрытия 'х' у диалога, то без кнопки справка 
    Dialog.setWindowFlags(QtCore.Qt.Dialog | QtCore.Qt.WindowCloseButtonHint);
 
    #Создадим список QListView
    SPISOK = QtWidgets.QListView(parent=Dialog)
    mod = QtGui.QStandardItemModel(parent=Dialog)
    lst = tek_s
    for row in range(0,len(tek_s)):
        stroka = QtGui.QStandardItem(tek_s[row])
        mod.appendRow([stroka])
 
    #Запрет на редактирование строк
    SPISOK.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
 
    #Зададим размеры
    Dialog.setFont(QtGui.QFont('Times', 13))
    
    #Сигнал
    #result = SPISOK.clicked.connect(vibor)     #По мышке
    result = SPISOK.activated.connect(vibor)    #По Enter
    print(result)
 
    SPISOK.setModel(mod)                        #Отображение
 
    #Встанем при открытии сразу на 1 строку
    #index = SPISOK.model().index(0, 0)
    #print (index)
    SPISOK.ItemIndex = 1
    
    
    Dialog.exec_()              #Показываем окно
    
    return result
 
 
def vibor(index):
    res = format(index.data())
    #print(res)
    Dialog.close()
    return res
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.12.2019, 17:02
Ответы с готовыми решениями:

Возврат значения функции show_selected
#!/usr/bin/env python3 # -*- coding: utf-8 -*- import json import argparse import os.path def add_prod(products, name,...

Pandas: Возврат значения при условии совпадения значения строки и столбца
Здравствуйте подскажите пожалуйста т.к. сам вот никак не могу найти хоть и задача вроде очень тривиальная: Допустим есть объект...

Scrapy возврат значения
Добрый день. Изучаю Scrapy и столкнулась с проблемой вывода конечного url при редиректе. Код вот: import scrapy import json ...

14
1293 / 677 / 367
Регистрация: 07.01.2019
Сообщений: 2,301
03.12.2019, 00:31
Слот не возвращают значения, надо через поля передавать
0
13 / 10 / 5
Регистрация: 11.10.2019
Сообщений: 290
03.12.2019, 11:06  [ТС]
Что-то не разобрался как передавать через поля. Через selected? Не получается пока.

Добавлено через 59 минут
Скорее всего надо использовать selectedIndexes() При открытии только срабатывает и то адакадабру выводит типа этого [<PyQt5.QtCore.QModelIndex object at 0x05267AB0>]

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
def FASTMENU(**kwargs):
    tek_zag = kwargs.get("zag")
    tek_s = kwargs.get("s")
 
    #Создаем диалоговое окно
    Dialog = QtWidgets.QDialog()
    Dialog.setWindowTitle(tek_zag)
    Dialog.resize(250,100)
    #Оставим только кнопку закрытия 'х' у диалога, то без кнопки справка 
    Dialog.setWindowFlags(QtCore.Qt.Dialog | QtCore.Qt.WindowCloseButtonHint);
 
    #Создадим список QListView
    SPISOK = QtWidgets.QListView(parent=Dialog)
    MOD = QtGui.QStandardItemModel(parent=Dialog)
    #lst = tek_s
    for row in range(0,len(tek_s)):
        stroka = QtGui.QStandardItem(tek_s[row])
        MOD.appendRow([stroka])
 
    #Запрет на редактирование строк
    SPISOK.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
    #Выделяется вся строка
    SPISOK.setSelectionBehavior(QtWidgets.QAbstractItemView.SelectRows)
    #Зададим размеры
    Dialog.setFont(QtGui.QFont('Times', 13))
    
    #Сигнал
    #result = SPISOK.clicked.connect(vibor)     #По мышке
    #result = SPISOK.activated.connect(vibor)    #По Enter
    #print(result)
    
    SPISOK.setModel(MOD)                        #Отображение
 
    #Встанем при открытии сразу на 1 строку
    SPISOK.setCurrentIndex(MOD.index(0,0))
 
    #попытаться получить значение по клику
    q=SPISOK.selectedIndexes()
    print(q)
    #print(q.data())
    #print(q.row())
    #print(q.column())
 
    
    Dialog.exec_()              #Показываем окно
    result=5
    return result
0
1293 / 677 / 367
Регистрация: 07.01.2019
Сообщений: 2,301
03.12.2019, 12:01
С этим QModelIndex можно из модели получить выбранное значение
0
13 / 10 / 5
Регистрация: 11.10.2019
Сообщений: 290
03.12.2019, 13:00  [ТС]
Как получить, объясните мне тупому. Суть такая выбрали строку и значение передаем в return и закрываем диалоговое окно.Все просто должно быть,с кнопками все ок,а вот со списком не доходит как делать.

Добавлено через 54 минуты
Чем больше мучаюсь,тем больше убеждаюсь,что без сигнала не обойтись. Но блин сигнал не возвращает ничего.
0
1293 / 677 / 367
Регистрация: 07.01.2019
Сообщений: 2,301
03.12.2019, 13:50
Цитата Сообщение от Сергей225 Посмотреть сообщение
что без сигнала не обойтись
Можно и сигналом сделать

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
import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import pyqtSignal
 
class CustomDialog(QDialog):
    val_Changed = pyqtSignal(int, name='valChanged')
 
    def __init__(self, *args, **kwargs):
        super(CustomDialog, self).__init__(*args, **kwargs)
        
        self.setWindowTitle("HELLO!")
        
        QBtn = QDialogButtonBox.Ok | QDialogButtonBox.Cancel
        
        self.buttonBox = QDialogButtonBox(QBtn)
        self.buttonBox.accepted.connect(self.accept)
        self.buttonBox.rejected.connect(self.reject)
 
        self.layout = QVBoxLayout()
        self.layout.addWidget(self.buttonBox)
        self.setLayout(self.layout)
 
    def accept(self):
        self.val_Changed.emit(5)
        super().accept()
 
class App(QWidget):
 
    def __init__(self):
        super().__init__()
        self.title = 'PyQt5'
        self.left = 100
        self.top = 100
        self.width = 320
        self.height = 200
        self.initUI()
    
    def initUI(self):
        self.setWindowTitle(self.title)
        self.setGeometry(self.left, self.top, self.width, self.height)
 
        self.dlg = CustomDialog(self)
        self.dlg.val_Changed[int].connect(self.get_signal)
        
        button = QPushButton('PyQt5 button', self)
        button.setToolTip('This is an example button')
        button.move(100,70)
        button.clicked.connect(self.on_click)
        
        self.show()
 
    def get_signal(self, val):
        print(val)
 
    def on_click(self):
        if self.dlg.exec_():
            print("Success!")
        else:
            print("Cancel!")
 
if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = App()
    sys.exit(app.exec_())
0
13 / 10 / 5
Регистрация: 11.10.2019
Сообщений: 290
03.12.2019, 15:23  [ТС]
Так надо разобраться. У меня нет классов,initов и __name__,просто тупо несколько функций в модуле,то есть def. Значит придется класс создавать(правда лишнее) и перенести функции некоторые в класс ну и как то выкручиваться и попробовать в конце класса вставить return и может вытащу из функции значение и на возврат вставлю.

Добавлено через 8 минут
Я из одного модуля лезу в этот модуль с которым мучаюсь и вернуть результат надо. То есть по сути дела делаю универсальное меню для разных проектов. Вот поэтому в том модуле откуда брать буду,там много будет функций всяких,вот поэтому и не пишу классы и прочее. Значит все дело в классе и инит? несколько классов придется писать,просто для того чтобы связать несколько функций в одном классе.

Вот пример куска в главном модуле.
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# Перехват событий
    def event(self, e):
        if e.type() == QtCore.QEvent.KeyPress:
            #print("Код:", e.key(), ", текст:", e.text())
            if e.key() == 16777269:     #Сортировка F6
                #print('сортировка')
 
                #меню
                vibor = ['по Наименованию', 'по Коду']
                results = FASTMENU(zag='ВЫБЕРИТЕ СОРТИРОВКУ', s=vibor)
                print(results)
                #После получения значения делаем что-то
 
            elif e.key() == 16777216:   #Закрытие по кнопке ESC  
                self.close()
 
        return QtWidgets.QMainWindow.event(self, e)
Добавлено через 1 час 7 минут
Что-то вообще заморочился. Не стал это все делать. Просто пару переменным глобальным сделал и все.

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
#МЕНЮ (Диалоговое окно со списком)
def FASTMENU(**kwargs):
    tek_zag = kwargs.get("zag")
    tek_s = kwargs.get("s")
  
    #Создаем диалоговое окно
    Dialog = QtWidgets.QDialog()
    global Dialog
    Dialog.setWindowTitle(tek_zag)
    Dialog.resize(250,100)
    #Оставим только кнопку закрытия 'х' у диалога, то без кнопки справка 
    Dialog.setWindowFlags(QtCore.Qt.Dialog | QtCore.Qt.WindowCloseButtonHint);
 
    #Создадим список QListView
    SPISOK = QtWidgets.QListView(parent=Dialog)
    MOD = QtGui.QStandardItemModel(parent=Dialog)
    #lst = tek_s
    for row in range(0,len(tek_s)):
        stroka = QtGui.QStandardItem(tek_s[row])
        MOD.appendRow([stroka])
 
    #Запрет на редактирование строк
    SPISOK.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
    #Выделяется вся строка
    SPISOK.setSelectionBehavior(QtWidgets.QAbstractItemView.SelectRows)
    #Зададим размеры
    Dialog.setFont(QtGui.QFont('Times', 13))
    
    #Сигнал
    #result = SPISOK.clicked.connect(vibor)     #По мышке
    result = SPISOK.activated.connect(vibor)    #По Enter
    
    SPISOK.setModel(MOD)                        #Отображение
    
    #Встанем при открытии сразу на 1 строку
    SPISOK.setCurrentIndex(MOD.index(0,0))
    
    Dialog.exec_()              #Показываем окно
 
    result=res
    #print(result)
    return result
 
 
def vibor(index):
    res = format(index.data())
    global res
    #print(res)
    Dialog.close()
    #return res
0
1293 / 677 / 367
Регистрация: 07.01.2019
Сообщений: 2,301
04.12.2019, 00:32
Цитата Сообщение от Сергей225 Посмотреть сообщение
Не стал это все делать. Просто пару переменным глобальным сделал и все.
Для начала сойдет, но лучше сделать как следует через классы
0
13 / 10 / 5
Регистрация: 11.10.2019
Сообщений: 290
04.12.2019, 09:21  [ТС]
Доброе утро. Да все равно буду в классы переделывать. Один вопрос.Почему не могу в функцию зайти по нажатию?Пробовал в слоте и self.vibor2 писать и в функции def vibor2(self,index): из за чего не работает сигнал?

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
class Test(QtWidgets.QDialog):
        
    def FASTMENU2(self,**kwargs):
        tek_zag = kwargs.get("zag")
        tek_s = kwargs.get("s")
 
        #Создаем диалоговое окно
        Dialog = QtWidgets.QDialog()
        Dialog.setWindowTitle(tek_zag)
        Dialog.resize(250,100)
        #Оставим только кнопку закрытия 'х' у диалога, то без кнопки справка 
        Dialog.setWindowFlags(QtCore.Qt.Dialog | QtCore.Qt.WindowCloseButtonHint);
 
        #Создадим список QListView
        SPISOK = QtWidgets.QListView(parent=Dialog)
        MOD = QtGui.QStandardItemModel(parent=Dialog)
        #lst = tek_s
        for row in range(0,len(tek_s)):
            stroka = QtGui.QStandardItem(tek_s[row])
            MOD.appendRow([stroka])
 
        #Запрет на редактирование строк
        SPISOK.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
        #Выделяется вся строка
        SPISOK.setSelectionBehavior(QtWidgets.QAbstractItemView.SelectRows)
        #Зададим размеры
        Dialog.setFont(QtGui.QFont('Times', 13))
        
####        #Сигнал
####        SPISOK.clicked.connect(self.vibor2)     #По мышке
        SPISOK.activated.connect(vibor2)    #По Enter
####        #result = SPISOK.activated.connect(self.get_signal)
####        #print(result)
####        
        SPISOK.setModel(MOD)                        #Отображение
 
        #Встанем при открытии сразу на 1 строку
        SPISOK.setCurrentIndex(MOD.index(0,0))
        
        Dialog.exec_()              #Показываем окно
        result1=6
        return result1
 
    def vibor2(index):
        print('проба')
Добавлено через 12 минут
Если сигнал таким способом SPISOK.activated.connect(vibor2) то функция должна быть не в классе и все ок заходит вроде.А вот как в классе переходить? Прописал SPISOK.activated.connect(self.vibor2) и функцию def vibor2(self,index): Заходить не хочет.Получается что сразу в сигнале ошибка то есть в слоте

Добавлено через 6 минут
Ошибка из-за return пока его скрыл,но в функцию все равно не заходит

Добавлено через 7 минут
Все дошло в чем проблема вот из за этого class Test(QtWidgets.QDialog): сделал в это class Test():

Добавлено через 10 минут
Вот окончательный вариант. Остался нерешенным вопрос по возврату значения обратно в главный модуль,который получили из функции vibor2. Сделал бы глобальным значение пока,но в init return нельзя писать как я понял.

главный модуль
Python
1
2
3
vibor = ['Наименование', 'Код']
result = FASTMENU2(zag='ВЫБЕРИТЕ СОРТИРОВКУ', s=vibor)
print(result)
И модуль в котором класс
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
class FASTMENU2():
        
    def __init__(self,**kwargs):
        tek_zag = kwargs.get("zag")
        tek_s = kwargs.get("s")
 
        #Создаем диалоговое окно
        self.Dialog = QtWidgets.QDialog()
        self.Dialog.setWindowTitle(tek_zag)
        self.Dialog.resize(250,100)
        #Оставим только кнопку закрытия 'х' у диалога, то без кнопки справка 
        self.Dialog.setWindowFlags(QtCore.Qt.Dialog | QtCore.Qt.WindowCloseButtonHint);
 
        #Создадим список QListView
        SPISOK = QtWidgets.QListView(parent=self.Dialog)
        MOD = QtGui.QStandardItemModel(parent=self.Dialog)
        #Заполним список
        for row in range(0,len(tek_s)):
            stroka = QtGui.QStandardItem(tek_s[row])
            MOD.appendRow([stroka])
 
        #Запрет на редактирование строк
        SPISOK.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
        #Выделяется вся строка
        SPISOK.setSelectionBehavior(QtWidgets.QAbstractItemView.SelectRows)
        #Зададим размеры
        self.Dialog.setFont(QtGui.QFont('Times', 13))
        
        #Сигнал
        #SPISOK.clicked.connect(self.vibor2)     #По мышке
        SPISOK.activated.connect(self.vibor2)    #По Enter
 
        
        SPISOK.setModel(MOD)                        #Отображение
 
        #Встанем при открытии сразу на 1 строку
        SPISOK.setCurrentIndex(MOD.index(0,0))
        
        self.Dialog.exec_()              #Показываем окно
        #result1=6
        #return result1
 
 
    def vibor2(self, index):
        res = format(index.data())
        #print(res)
        self.Dialog.close()
0
1293 / 677 / 367
Регистрация: 07.01.2019
Сообщений: 2,301
04.12.2019, 09:34
Вы не с той стороны функцию exec_() вызываете, она должна быть на принимающей стороне, вот так можно передать значение из диалога без сигнала

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
import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import pyqtSignal
 
class CustomDialog(QDialog):
    def __init__(self, *args, **kwargs):
        super(CustomDialog, self).__init__(*args, **kwargs)
        
        self.setWindowTitle("HELLO!")
        
        QBtn = QDialogButtonBox.Ok | QDialogButtonBox.Cancel
        
        self.buttonBox = QDialogButtonBox(QBtn)
        self.buttonBox.accepted.connect(self.accept)
        self.buttonBox.rejected.connect(self.reject)
 
        self.layout = QVBoxLayout()
        self.layout.addWidget(self.buttonBox)
        self.setLayout(self.layout)
 
    def accept(self):
        self.val = 5
        super().accept()
 
class App(QWidget):
 
    def __init__(self):
        super().__init__()
        self.title = 'PyQt5'
        self.left = 100
        self.top = 100
        self.width = 320
        self.height = 200
        self.initUI()
    
    def initUI(self):
        self.setWindowTitle(self.title)
        self.setGeometry(self.left, self.top, self.width, self.height)
        
        button = QPushButton('PyQt5 button', self)
        button.setToolTip('This is an example button')
        button.move(100,70)
        button.clicked.connect(self.on_click)
        
        self.show()
 
    def on_click(self):
        dlg = CustomDialog(self)
        if dlg.exec_():
            print(dlg.val)
 
if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = App()
    sys.exit(app.exec_())
0
13 / 10 / 5
Регистрация: 11.10.2019
Сообщений: 290
04.12.2019, 09:50  [ТС]
Ничего не понял.Хотите чтобы я exec перенес в функцию vibor2?Тогда ничего не откроется,вернее диалоговое окно

Вот весь полностью код в модуле в котором функция. Больше там ничего нету по крайней мере пока.Все ок осталось только вернуть значение из этого файла(модуля) обратно в котором вызвал класс.
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
from PyQt5 import Qt, QtCore, QtGui, QtWidgets
 
#МЕНЮ (Диалоговое окно со списком)
class FASTMENU2():   
    def __init__(self,**kwargs):
        tek_zag = kwargs.get("zag")
        tek_s = kwargs.get("s")
 
        #Создаем диалоговое окно
        self.Dialog = QtWidgets.QDialog()
        self.Dialog.setWindowTitle(tek_zag)
        self.Dialog.resize(250,100)
        #Оставим только кнопку закрытия 'х' у диалога, то без кнопки справка 
        self.Dialog.setWindowFlags(QtCore.Qt.Dialog | QtCore.Qt.WindowCloseButtonHint);
 
        #Создадим список QListView
        SPISOK = QtWidgets.QListView(parent=self.Dialog)
        MOD = QtGui.QStandardItemModel(parent=self.Dialog)
        #Заполним список
        for row in range(0,len(tek_s)):
            stroka = QtGui.QStandardItem(tek_s[row])
            MOD.appendRow([stroka])
 
        #Запрет на редактирование строк
        SPISOK.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
        #Выделяется вся строка
        SPISOK.setSelectionBehavior(QtWidgets.QAbstractItemView.SelectRows)
        #Зададим размеры
        self.Dialog.setFont(QtGui.QFont('Times', 13))
        
        #Сигнал
        #SPISOK.clicked.connect(self.vibor)     #По мышке
        SPISOK.activated.connect(self.vibor)    #По Enter
        
        SPISOK.setModel(MOD)                    #Отображение модели
 
        #Встанем при открытии сразу на 1 строку
        SPISOK.setCurrentIndex(MOD.index(0,0))
        
        self.Dialog.exec_()                     #Показываем окно
        #result1=6
        #return result1
 
    
    def vibor(self, index):
        res = format(index.data())
        #print(res)
        self.Dialog.close()
        #return res
0
1293 / 677 / 367
Регистрация: 07.01.2019
Сообщений: 2,301
04.12.2019, 10:12
Лучший ответ Сообщение было отмечено Сергей225 как решение

Решение

Вот так

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
from PyQt5 import Qt, QtCore, QtGui, QtWidgets
import sys
#МЕНЮ (Диалоговое окно со списком)
class FASTMENU2(QtWidgets.QDialog):   
    def __init__(self, *args, **kwargs):
        super().__init__()
 
        tek_zag = kwargs.get("zag")
        tek_s = kwargs.get("s")
 
        #Создаем диалоговое окно
        self.setWindowTitle(tek_zag)
        self.resize(250,100)
        #Оставим только кнопку закрытия 'х' у диалога, то без кнопки справка 
        self.setWindowFlags(QtCore.Qt.Dialog | QtCore.Qt.WindowCloseButtonHint);
 
        #Создадим список QListView
        SPISOK = QtWidgets.QListView(parent=self)
        MOD = QtGui.QStandardItemModel(parent=self)
        #Заполним список
        for row in range(0,len(tek_s)):
            stroka = QtGui.QStandardItem(tek_s[row])
            MOD.appendRow([stroka])
 
        #Запрет на редактирование строк
        SPISOK.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
        #Выделяется вся строка
        SPISOK.setSelectionBehavior(QtWidgets.QAbstractItemView.SelectRows)
        #Зададим размеры
        self.setFont(QtGui.QFont('Times', 13))
        
        #Сигнал
        #SPISOK.clicked.connect(self.vibor)     #По мышке
        SPISOK.activated.connect(self.vibor)    #По Enter
        
        SPISOK.setModel(MOD)                    #Отображение модели
 
        #Встанем при открытии сразу на 1 строку
        SPISOK.setCurrentIndex(MOD.index(0,0))
 
        
        # self.Dialog.exec_()                     #Показываем окно
        #result1=6
        #return result1
 
    
    def vibor(self, index):
        self.res = format(index.data())
        #print(res)
        super().accept() # диалог успешно завершился, встроенная функция
        #return res
 
 
app = QtWidgets.QApplication(sys.argv)
vibor = ['Наименование', 'Код']
ex = FASTMENU2(zag='ВЫБЕРИТЕ СОРТИРОВКУ', s=vibor)
if ex.exec_():
    print(ex.res)
sys.exit(app.exec_())
1
13 / 10 / 5
Регистрация: 11.10.2019
Сообщений: 290
04.12.2019, 13:20  [ТС]
Все наконец-то решил проблему. Вопрос можно закрывать. tooru отдельное спасибо,что не остался в стороне. В каких то моментах ты мне все равно помог.

Вот как делается.

в этом модуле а именно в функции допишем к переменной res слово self
Python
1
2
3
4
def vibor(self, index):
        self.res = format(index.data())
        #print(res)
        self.Dialog.close()
А вот в главном модуле получаем значение так,то есть через result.res
Python
1
2
3
4
5
6
 #меню
 vibor = ['Наименование', 'Код']
 result = FASTMENU2(zag='ВЫБЕРИТЕ СОРТИРОВКУ', s=vibor)
#print(result)
re=result.res
print(re)
Добавлено через 3 часа 6 минут
Напишу еще вопрос

Python
1
2
3
4
5
vibor = ['Наименование', 'Код']
 result = FASTMENU2(zag='ВЫБЕРИТЕ СОРТИРОВКУ', s=vibor)
#print(result)
re=result.res
print(re)
Вопрос такой,что возвращает переменная result или re если мы ничего не выбрали? например открыто диалоговое окно и ничего не выбрал и хочу закрыть окно по крестику или по esc,но вылетает ошибка. Если ничего не выбрали и попытались закрыть будет ошибка в этой переменной re=result.res Решил условие вставить, что если пустое значение то ничего не делать,но выдает все равно ошибку,с чем надо сравнивать? Вроде пустое должно быть по логике или None,то есть if re=='' or re==None: Скорее всего надо сравнивать с result но он выдает адакадабру <lib.functions.FASTMENU object at 0x0657EA90> как его и с чем сравнивать?
0
1293 / 677 / 367
Регистрация: 07.01.2019
Сообщений: 2,301
04.12.2019, 13:30
Если метод vibor не срабатывает, то переменной res в классе не будет, надо в __init__ написать

Python
1
self.res = None
1
13 / 10 / 5
Регистрация: 11.10.2019
Сообщений: 290
04.12.2019, 15:43  [ТС]
В функцию не зашли,значит нечего извлекать и переменной не существует.Как проверить на существование переменной?
Хотел что-то такое написать if result.res in result(): ,но пока не удается.

Добавлено через 1 минуту
tooru, О спасибон. Опять выручили. Все вопрос закрыт.

Добавлено через 2 часа 5 минут
Еще интересно узнать,вдруг понадобится. Как можно разделить сигнал для разных функций в зависимости от выбора из списка.
Например:
SPISOK.activated.connect(self.vibor)
SPISOK.activated.connect(self.vibor2)

Добавлено через 4 минуты
А все дошло. Никак. Просто в функции условия создать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.12.2019, 15:43
Помогаю со студенческими работами здесь

Возврат значения функции
Что такое возврат значения функции? я уже всю голову изломал, что и куда возвращается? в гугле нашёл мол возвращается результат (куда? в...

Возврат значения из функции
Добрый день! Прошу помочь, нужно чтоб при открытии окна появлялась кнопка, потом при нажатии на неё появлялось модальное окно, куда мы...

Возврат значения функции
Здравствуйте. Проблемма..... есть ф-я в паскале , как мне возвратить значение функции через asm mov CompileTest,ax - материться на это...

Возврат значения из функции
Добрый вечер. Вопрос следующий , как возвратить из функции create последнее значение ЛС , чтоб в дальнейшем использовать в main. ...

Возврат значения из функции
Два аргумента функции, объявляю одинаково, в главном модуле объявляю анологичные переменные ID и Hash. После выхода из функции переменная...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru