如何通过单击pyqt5中的按钮来制作qlineedit的动态行和列?

Posted

技术标签:

【中文标题】如何通过单击pyqt5中的按钮来制作qlineedit的动态行和列?【英文标题】:How to make dynamic row and columns of qlineedit on a click of pushbutton in pyqt5? 【发布时间】:2019-09-14 20:53:05 【问题描述】:

我正在开发一个库存管理软件项目,其中我有一小部分是一些 qlineedits 和 qlable 的集合,只需单击一个按钮即可创建,

即默认情况下,将打开一个排列,如下所示

lineedit   lineEdit   lable  pushbutton

在上面的安排中,当我单击按钮时,将创建一个与上面相同的安排的新行,我在下面用一个代码示例显示,这些 lineedit 中的数据将保存在一个数组中

lineedit   lineEdit   lable  pushbutton
lineedit   lineEdit   lable  pushbutton
lineedit   lineEdit   lable  pushbutton

我实际上没有得到确切的方法来做到这一点,我尝试了不同的方法,使用 for 循环创建它并使用方法安排创建上述内容,但都有一些问题,任何人都可以提供必要的算法或代码我可以修改或使用?

如图所示,我想在产品细节部分实现代码

代码:

class Ui_MainWindow(QObject):

    def setupUi2(self, MainWindow):

        MainWindow.setObjectName("MainWindow")
        MainWindow.setEnabled(True)
        MainWindow.resize(1500, 799)
        sizePolicy = QtWidgets.QSizePolicy(QtWidgets.QSizePolicy.Minimum, QtWidgets.QSizePolicy.Minimum)
............
............
        self.CREATEBILL = QtWidgets.QWidget()
        self.CREATEBILL.setObjectName("CREATEBILL")
        self.gridLayout_7 = QtWidgets.QGridLayout(self.CREATEBILL)
      ............
..................
       # where to implement codes
        self.splitter_15 = QtWidgets.QSplitter(self.scrollAreaWidgetContents_9)
        sizePolicy = QtWidgets.QSizePolicy(QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Fixed)
        sizePolicy.setHorizontalStretch(0)
        sizePolicy.setVerticalStretch(0)     
sizePolicy.setHeightForWidth(self.splitter_15.sizePolicy().hasHeightForWidth())

我尝试过的代码,但按照@oetzi 的教导失败了:


class Widget(QWidget):
    form_group_box = None
    layout = None
    row_counter = None

    def __init__(self):
        super(QWidget, self).__init__()
        self.row_counter = 0
        self.create_form_groupbox()
        button_box = QDialogButtonBox(QDialogButtonBox.Ok | QDialogButtonBox.Cancel)
        button_box.accepted.connect(self._insert)
        button_box.rejected.connect(self._exit)
        button_box.button(QDialogButtonBox.Ok).setText("Insert")
        button_box.button(QDialogButtonBox.Cancel).setText("Cancel")

        main_layout = QVBoxLayout()
        main_layout.addWidget(self.form_group_box)
        main_layout.addWidget(button_box)
        self.setLayout(main_layout)
        self.setWindowTitle("form example")

    def _insert(self):
        self._insert_row_component()
        i = self.row_counter
        print(i)
        a = i - 2
        b = self.qline_edit1[a].text()
        print(b)


    def _exit(self):
        pass

    def _insert_row_component(self):

        i = self.row_counter

        self.qline_edit1 = [None]*i
        self.qline_edit1.append(self.qline_edit1)
        self.qline_edit1[i] = QLineEdit()
        self.qline_edit1[i].setPlaceholderText("enter text1")

        push_button = QPushButton("push button")
        push_button.clicked.connect(self._on_push_button_clicked)

        qline_edit2 = QLineEdit()
        qline_edit2.setPlaceholderText("enter text2")

        qline_edit3 = QLineEdit()
        qline_edit3.setPlaceholderText("enter text3")
        qline_edit4 = QLineEdit()
        qline_edit4.setPlaceholderText("enter text4")
        qlabel = QLabel("label")


        self.layout.addWidget(self.qline_edit1[i], self.row_counter, 0)
        self.layout.addWidget(qline_edit2, self.row_counter, 1)

        self.layout.addWidget(qline_edit3, self.row_counter, 3)
        self.layout.addWidget(qline_edit4, self.row_counter, 2)

        self.layout.addWidget(qlabel, self.row_counter, 4)
        self.layout.addWidget(push_button, self.row_counter, 5)
        self.row_counter = self.row_counter + 1



    def _on_push_button_clicked(self):
        # TODO implement
        print("button clicked")
        a = self.qline_edit1[1].text()
        print(a)

    def create_form_groupbox(self):
        self.form_group_box = QGroupBox("Form layout")
        self.layout = QGridLayout()
        self._insert_row_component()
        self.form_group_box.setLayout(self.layout)

if __name__ == '__main__':
    app = QApplication(sys.argv)
    widget = Widget()
    widget.show()
    sys.exit(app.exec_())

但遇到不同的错误: 的

'NoneType' object has no attribute 'text'

【问题讨论】:

您遇到了什么问题?至少给我们一个minimal, reproducible example,然后我们可以尝试帮助您了解其中的问题。 【参考方案1】:

from PyQt5.QtWidgets import (QApplication, QPushButton, QWidget, QDialogButtonBox, QGridLayout, QLabel, QLineEdit,
                                 QVBoxLayout, QGroupBox)

import sys


class Widget(QWidget):
    form_group_box = None
    layout = None
    row_counter = None

    def __init__(self):
        super(QWidget, self).__init__()
        self.row_counter = 0
        self.create_form_groupbox()
        button_box = QDialogButtonBox(QDialogButtonBox.Ok | QDialogButtonBox.Cancel)
        button_box.accepted.connect(self._insert)
        button_box.rejected.connect(self._exit)
        button_box.button(QDialogButtonBox.Ok).setText("Insert")
        button_box.button(QDialogButtonBox.Cancel).setText("Cancel")

        main_layout = QVBoxLayout()
        main_layout.addWidget(self.form_group_box)
        main_layout.addWidget(button_box)
        self.setLayout(main_layout)
        self.setWindowTitle("form example")

    def _insert(self):
        self._insert_row_component()

    def _exit(self):
        pass

    def _insert_row_component(self):
        push_button = QPushButton("push button")
        push_button.clicked.connect(self._on_push_button_clicked)
        qline_edit1 = QLineEdit()
        qline_edit1.setPlaceholderText("enter text")
        qline_edit2 = QLineEdit()
        qline_edit2.setPlaceholderText("enter text")
        qlabel = QLabel("label")
        self.layout.addWidget(qline_edit1, self.row_counter, 0)
        self.layout.addWidget(qline_edit2, self.row_counter, 1)
        self.layout.addWidget(qlabel, self.row_counter, 2)
        self.layout.addWidget(push_button, self.row_counter, 3)
        self.row_counter = self.row_counter + 1

    def _on_push_button_clicked(self):
        # TODO implement
        print("button clicked")

    def create_form_groupbox(self):
        self.form_group_box = QGroupBox("Form layout")
        self.layout = QGridLayout()
        self._insert_row_component()
        self.form_group_box.setLayout(self.layout)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    widget = Widget()
    widget.show()
    sys.exit(app.exec_())

【讨论】:

先生,我有一个问题,因为我的班级是 QObject 并且我已经编辑了我的问题并显示了一个代码,当您在课堂上使用 QWidget 时,如何将您的代码写入这意味着您的答案非常正确。感谢您的回复和回答 先生,它作为逻辑工作得很好,但是如果我在其中插入了多行,如何将数据输入到变量以及如何从第一个输入区域获取数据 从这个函数_insert_row_component的内容创建一个类。并将数据对象实现为每个操作要插入的组件的值集合。所以它有自己的实例和数据对象。这样您可以更好地跟踪运行时正在编辑的行/组件 我已经按照你说的做了,但是它显示的值是 'NoneType' 对象没有属性 'text' 我不知道为什么我在代码中得到这个错误,如果我调用对象它再次显示此错误的第 0 个或任何值。 我已经编辑了问题并给出了我在您的代码上更新的代码,请查看结果错误。

以上是关于如何通过单击pyqt5中的按钮来制作qlineedit的动态行和列?的主要内容,如果未能解决你的问题,请参考以下文章

如何在每个 Qlabel PyQt5 中显示两个图像

如何通过单击 tkinter 中的按钮来运行 python 文件?

如何断开 PySide2 中的按钮单击信号?

在pyqt5中单击登录按钮时获取小部件未定义错误

QLineEdit 单击时清除文本并从按钮读取文本[关闭]

如何在pyqt5中将按钮移动到另一个框架?