如何实现用输入的时间对表数据的更新?

怎么通过用上面输入的两个时间,更新下面表的数据?

比如输入时间“2022-6-15 10:49:11” ---“2022-7-15 10:49:11” 就能显示“intime” 在这个时间范围内的数据。

img

代码如下:

from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtGui import QIcon
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
import pandas as pd
import numpy as np
import getfile


class Ui_MainWindow(QMainWindow):

    def __init__(self):
        super(QtWidgets.QMainWindow, self).__init__()
        self.setupUi(self)
        self.retranslateUi(self)

    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(880, 800)
        self.centralWidget = QtWidgets.QWidget(MainWindow)
        self.centralWidget.setObjectName("centralWidget")
        self.retranslateUi(MainWindow)

        self.tableWidget = QtWidgets.QTableWidget(self.centralWidget)
        self.tableWidget.setGeometry(QtCore.QRect(100, 60, 670, 700))
        self.tableWidget.setObjectName("tableWidget")
        self.tableWidget.setColumnCount(0)
        self.tableWidget.setRowCount(0)
        self.tableWidget.setStyleSheet("selection-background-color:pink")
        self.tableWidget.setEditTriggers(QAbstractItemView.NoEditTriggers)
        self.tableWidget.raise_()

        self.pushButton = QtWidgets.QPushButton(self.centralWidget)
        self.pushButton.setGeometry(QtCore.QRect(100, 20, 75, 23))
        self.pushButton.setObjectName("pushButton")
        self.pushButton.setText("运行")
        self.pushButton.clicked.connect(self.OpenClick)

        self.pushButton = QtWidgets.QPushButton(self.centralWidget)
        self.pushButton.setGeometry(QtCore.QRect(220, 20, 75, 23))
        self.pushButton.setObjectName("pushButton1")
        self.pushButton.setText("打开")
        MainWindow.setCentralWidget(self.centralWidget)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)
        self.pushButton.clicked.connect(self.openfile)
        self.pushButton.clicked.connect(self.creat_table_show)

        self.startDateEdit = QtWidgets.QDateTimeEdit(self.centralWidget)
        self.startDateEdit.setDateTime(QtCore.QDateTime(QtCore.QDate(2022, 7, 15), QtCore.QTime(0, 0, 10)))
        self.startDateEdit.setGeometry(QtCore.QRect(330, 20, 150, 23))
        self.startDateEdit.setObjectName("startDateEdit")

        self.endDateEdit = QtWidgets.QDateTimeEdit(self.centralWidget)
        self.endDateEdit.setDateTime(QtCore.QDateTime(QtCore.QDate(2022, 7, 15), QtCore.QTime(0, 0, 10)))
        self.endDateEdit.setGeometry(QtCore.QRect(520, 20, 150, 23))
        self.endDateEdit.setObjectName("endDateEdit")


    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "报表系统"))


    def OpenClick(self):
        getfile.FunctionAlgo()
    def openfile(self):

        openfile_name = QFileDialog.getOpenFileName(self, '选择文件', 'C:\\出入站时间.xls', 'Excel files(*.xlsx , *.xls)')
        # print(openfile_name)
        global path_openfile_name
        path_openfile_name = openfile_name[0]

    def creat_table_show(self):
        ###===========读取表格,转换表格,===========================================
        if len(path_openfile_name) > 0:
            input_table = pd.read_excel(path_openfile_name)
            # print(input_table)
            input_table_rows = input_table.shape[0]
            input_table_colunms = input_table.shape[1]
            # print(input_table_rows)
            # print(input_table_colunms)
            input_table_header = input_table.columns.values.tolist()
            # print(input_table_header)

            ###===========读取表格,转换表格,============================================
            ###======================给tablewidget设置行列表头============================

            self.tableWidget.setColumnCount(input_table_colunms)
            self.tableWidget.setRowCount(input_table_rows)
            self.tableWidget.setHorizontalHeaderLabels(input_table_header)

            ###======================给tablewidget设置行列表头============================

            ###================遍历表格每个元素,同时添加到tablewidget中========================
            for i in range(input_table_rows):
                input_table_rows_values = input_table.iloc[[i]]
                # print(input_table_rows_values)
                input_table_rows_values_array = np.array(input_table_rows_values)
                input_table_rows_values_list = input_table_rows_values_array.tolist()[0]
                # print(input_table_rows_values_list)
                for j in range(input_table_colunms):
                    input_table_items_list = input_table_rows_values_list[j]
                    # print(input_table_items_list)
                    # print(type(input_table_items_list))

                    ###==============将遍历的元素添加到tablewidget中并显示=======================

                    input_table_items = str(input_table_items_list)
                    newItem = QTableWidgetItem(input_table_items)
                    newItem.setTextAlignment(Qt.AlignHCenter | Qt.AlignVCenter)
                    self.tableWidget.setItem(i, j, newItem)

                    ###================遍历表格每个元素,同时添加到tablewidget中========================
        else:
            self.centralWidget.show()


if __name__ == "__main__":
    import sys

    app = QtWidgets.QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())

QTime、QDateTime都重载了==,可以直接比较,
将界面上输入的时间和列表中的时间转化成QTime或者QDateTime来对比,满足的就加入一个vector或者list中