PyQt-将组合框文本传递给变量

时间:2019-03-21 20:02:54

标签: python pyqt

我有一个组合框下拉列表,其中包含来自SQL查询的客户列表。我有一个名为FinalButton的其他按钮,我想在其中执行其他操作。其中之一将要求我在组合框中获取客户名称,并将其存储在变量中以供FinalButton使用。

import sys
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtWidgets import QFileDialog, QMessageBox
from config_assign_ui import Ui_ConfigAssign
import pyodbc
import pandas as pd

class Main(QtWidgets.QMainWindow, Ui_ConfigAssign):
    def __init__(self):
        QtWidgets.QMainWindow.__init__(self)
        self.setupUi(self)
        self.combo_list()
        self.FinalButton.clicked.connect(self.final_button)


    def combo_list(self):
        self.customerlistbox.clear()
        conn = pyodbc.connect(
            r'DRIVER={ODBC Driver 13 for SQL Server};'
            r'SERVER=server;'
            r'DATABASE=db;'
            r'Trusted_Connection=yes;'
            )

        querystring = """SELECT CustomerName
                         FROM [CustomerTable]"""

        cursor = conn.cursor()
        cursor.execute(querystring)
        customerlist = []
        # Dump results into a list called customerlist
        customerlist = [row[0] for row in cursor.fetchall()]
        for i in customerlist:
            self.customerlistbox.addItem(str(i))

    def final_button(self):
        print(self.customerlistbox.itemText())

最后一行产生TypeError:itemText(self,int):参数不足。如何实现我想要的?

1 个答案:

答案 0 :(得分:1)

itemText()是一种返回给定索引的项目文本的方法,在这种情况下,您无需传递它。我认为您所需要的是所选项目的文本,为此您必须使用currentText()

def final_button(self):
    print(self.customerlistbox.currentText())