如何使用QDate选择更新QTableView单元?

时间:2018-01-06 23:10:31

标签: python pyqt pyqt5 qtableview qdatetime

我已将QDateEdit委托添加到QTableView单元格中,并希望使用日期更新它们,但我无法找出正确的连接语法。 dateChanged.connect(item.setText)不起作用,因为QDateEdit返回一个QDate对象,需要将其转换为 toString 的字符串,但我不知道在 connect()语句中知道在何处以及如何挤压它。

这是我到目前为止所做的:

main.ui

<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>Dialog</class>
 <widget class="QDialog" name="Dialog">
  <property name="geometry">
   <rect>
    <x>0</x>
    <y>0</y>
    <width>350</width>
    <height>239</height>
   </rect>
  </property>
  <property name="windowTitle">
   <string>Dialog</string>
  </property>
  <widget class="QWidget" name="formLayoutWidget">
   <property name="geometry">
    <rect>
     <x>0</x>
     <y>0</y>
     <width>341</width>
     <height>231</height>
    </rect>
   </property>
   <layout class="QFormLayout" name="formLayout">
    <item row="0" column="1">
     <widget class="QPushButton" name="btnPopulate">
      <property name="text">
       <string>Populate Table</string>
      </property>
     </widget>
    </item>
    <item row="1" column="1">
     <widget class="QTableView" name="tableView"/>
    </item>
   </layout>
  </widget>
 </widget>
 <resources/>
 <connections/>
</ui>

test.py

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import sys, os
from PyQt5 import uic
from PyQt5.QtGui import QStandardItemModel
from PyQt5.QtWidgets import QDialog, QApplication, QDateEdit
from PyQt5.QtCore import QDate

class GUI(QDialog):

    def __init__(self):
        super(GUI, self).__init__()
        dirname = os.path.dirname(os.path.abspath(__file__))
        uic.loadUi(os.path.join(dirname,'main.ui'), self)
        # button
        self.btnPopulate.clicked.connect(self.populate)
        # table model
        self.header = ['col1', 'col2', 'col3']
        self.QSModel = QStandardItemModel()
        self.QSModel.setColumnCount(3)
        self.QSModel.setHorizontalHeaderLabels(self.header)
        self.tableView.setModel(self.QSModel)

    def populate(self):
        row = self.QSModel.rowCount()
        for x in range(7):
            self.QSModel.insertRow(row)
            self.QSModel.setData(self.QSModel.index(row, 0), 'data')
            self.QSModel.item(row, 0).setEditable(True)
            self.QSModel.setData(self.QSModel.index(row, 1), 'data')
            self.QSModel.item(row, 1).setEditable(True)
            if x % 2 == 0:
                self.QSModel.setData(self.QSModel.index(row, 2), '2018-01-06')
                item = self.tableView.model().item(row, 2)
                date = self.QSModel.data(self.QSModel.index(row, 2))
                deDelegate = QDateEdit()
                deDelegate.setCalendarPopup(True)
                deDelegate.setDisplayFormat('yyyy-MM-dd')
                myQDate = QDate.fromString(date, 'yyyy-MM-dd')
                deDelegate.setDate(myQDate)
                self.tableView.setIndexWidget(item.index(), deDelegate)
                #deDelegate.dateChanged.connect(item.setText) doesn't work
            else:
                self.QSModel.setData(self.QSModel.index(row, 2), 'data')

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

我有以下问题:

  1. 正确的 connect()语法是什么来实现我想要的。

  2. AFAIK, yyyy-MM-dd Qt.ISODate 格式相同,但我无法弄清楚正确的导入语法。 (我尝试从PyQt5.QtCore导入它,但它没有用。)如果我可以使用 Qt.ISODate 而不是 yyyy-MM-dd :什么是正确的导入语法?

1 个答案:

答案 0 :(得分:1)

  

正确的connect()语法是什么来实现我想要的。

dateChanged信号返回QDate类型的对象,它不是字符串,因此您无法将其分配给setText(),为此您必须使用toString()

deDelegate.dateChanged.connect(lambda date, it=item: it.setText(date.toString(Qt.ISODate)))

或者:

deDelegate.dateChanged.connect(lambda date, it=item: it.setText(date.toString("yyyy-MM-dd")))
  

AFAIK,yyyy-MM-dd与Qt.ISODate格式相同,但我无法弄清楚正确的导入语法。 (我尝试从PyQt5.QtCore导入它,但它没有用。)如果我可以使用Qt.ISODate而不是yyyy-MM-dd:什么是正确的导入语法?

QtQtCore的一部分,因此您必须按以下方式导入它:from PyQt5.QtCore import Qt,例如:

from PyQt5.QtCore import QDate, Qt

if __name__ == '__main__':
    today = QDate.currentDate()
    print(today.toString(Qt.ISODate))