我有一个组合框下拉列表,其中包含来自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):参数不足。如何实现我想要的?
答案 0 :(得分:1)
itemText()
是一种返回给定索引的项目文本的方法,在这种情况下,您无需传递它。我认为您所需要的是所选项目的文本,为此您必须使用currentText()
def final_button(self):
print(self.customerlistbox.currentText())