前文:
PyQt5学习笔记9 - QPushButton & QRadioButton
PyQt5学习笔记10 - QCheckBox & QComboBox
PyQt5学习笔记11 - QSpinBox & QSlider
PyQt5学习笔记12 - QMenubar & QStatusBar
PyQt5学习笔记13 - QDialog & QMessageBox
日历和事件
QCalendar 日历
QCalendar是一个日历控件,它提供了一个基于月份的视图,允许用户通过鼠标或键盘选择日期,默认选中今天的日期。也可以对日历的日期范围进行规定。
QCalendar 常用方法如下
方法 | 描述 |
---|---|
setDataRange() |
设置日期范围供选择 |
setFirstDayOfWeek() |
重新设置星期的第一天,默认是星期日。参数枚举(Qt.Monday , Qt.Tuesday , Qt.Wednesday ...) |
setMinimumDate() |
设置最小日期 |
setMaximumDate() |
设置最大日期 |
setSelectedDate() |
设置一个QDate对象,作为日期控件所选定的日期 |
maximumDate() |
获取日历控件最大的日期 |
minimumDate() |
获取日历控件最小的日期 |
selectedDate() |
返回当前选定的日期 |
setGridvisible() |
设置日历控件是否显示网格 |
实例: QCalendar的使用
import sys
from PyQt5 import QtCore
from PyQt5.QtCore import QDate
from PyQt5.QtGui import QIcon
from PyQt5.QtWidgets import QWidget, QCalendarWidget, QLabel, QApplication, QVBoxLayout
class QCalenderDemo(QWidget):
def __init__(self):
super(QCalenderDemo, self).__init__()
self.calender = QCalendarWidget()
self.label = QLabel()
self.init_ui()
def init_ui(self):
self.calender.setMinimumDate(QDate(1980, 1, 1))
self.calender.setMaximumDate(QDate(3000, 1, 1))
self.calender.setGridVisible(True)
self.calender.move(20, 20)
self.calender.clicked.connect(lambda: self.show_date(self.calender.selectedDate()))
# self.calender.clicked[QtCore.QDate].connect(self.show_date)
date = self.calender.selectedDate()
self.label.setText(date.toString('yyyy-MM-dd dddd'))
self.label.move(20, 20)
self.setGeometry(100, 100, 400, 350)
self.setWindowTitle('Calender Demo')
self.setWindowIcon(QIcon('../image/python.png'))
layout = QVBoxLayout(self)
layout.addWidget(self.calender)
layout.addWidget(self.label)
self.setLayout(layout)
def show_date(self, date: QDate):
self.label.setText(date.toString('yyyy-MM-dd dddd'))
if __name__ == '__main__':
app = QApplication(sys.argv)
demo = QCalenderDemo()
demo.show()
sys.exit(app.exec_())
每当点击日历控件的时候连接到槽函数show_date
, 并且接受一个QDate
对象将其传入到Qlabel
中.
self.calender.clicked.connect(lambda: self.show_date(self.calender.selectedDate()))
或者使用以下方式,在窗口组件选定一个日期的时候发射一个QCore.QDate
信号, 同连接到槽函数show_date
self.calender.clicked[QCore.Qdate].connect(self.show_date)
QDateTimeEdit
QDateTimeEdit是一个允许用户便利日期事件的控件, 可以使用键盘和上下箭头按钮来增减日期时间。QDateTimeEdit通过setDisplayFormat()
函数来设置显示的日期事件格式。
QDateTimeEdit常用的方法
方法 | 描述 |
---|---|
setDisplayFormat() |
设置日期时间格式 - yyyy,年份 - MM,月份 - dd,日 - HH,小时 - mm,分钟 - ss,秒 |
setMinimumDate() |
设置控件的最小日期 |
setMaximumDate() |
设置控件的最大日期 |
time() |
返回编辑的时间 |
date() |
返回编辑的日期 |
QDateTimeEdit类中的常用信号
信号 | 含义 |
---|---|
dateChanged |
当日期改变时发射此信号 |
dateTimeChanged |
当日期事件改变时发射此信号 |
timeChanged |
当时间改变时发射此信号 |
QDateEdit和QTimeEdit
QDateEdit
和QTimeEdit
均继承自QDateTimeEdit
. 因此很多特性和功能都由QDateTimeEdit
提供。
-
QDateEdit
仅支持编辑年月日。 -
QTimeEdit
仅支持编辑时分秒。
QDateEdit
和QTimeEdit
类的继承结构如下:
QWidget
|
QAbstractSpinBox
|
+-- QDateTimeEdit
|
+-- QDateEdit
|
+-- QTimeEdit
Note:设置弹出日历的时候,用来弹出日历的类只有QDateTimeEdit
和QDateEdit
, 虽然QTimeEdit
可以设置,但是不起作用
实例:QDateTimeEdit的使用
import sys
from PyQt5.QtCore import QDateTime, QDate
from PyQt5.QtWidgets import QWidget, QVBoxLayout, QDateTimeEdit, QPushButton, QApplication
class DateTimeEditDemo(QWidget):
def __init__(self):
super(DateTimeEditDemo, self).__init__()
self.date_edit = QDateTimeEdit(QDateTime.currentDateTime(), self)
self.button = QPushButton('获取日期和时间')
self.init_ui()
def init_ui(self):
self.setWindowTitle('QDateTimeEditDemo')
self.resize(300, 90)
layout_v = QVBoxLayout()
self.date_edit.setDisplayFormat('yyyy-MM-dd HH:mm:ss')
self.date_edit.setMinimumDate(QDate.currentDate().addDays(-365))
self.date_edit.setMaximumDate(QDate.currentDate().addDays(365))
self.date_edit.setCalendarPopup(True)
self.date_edit.dateChanged.connect(self.date_changed_event)
self.date_edit.timeChanged.connect(self.time_changed_event)
self.date_edit.dateTimeChanged.connect(self.datetime_changed_event)
self.button.clicked.connect(self.button_event)
layout_v.addWidget(self.date_edit)
layout_v.addWidget(self.button)
self.setLayout(layout_v)
@staticmethod
def date_changed_event(date: QDate) -> None:
print(date.toString())
@staticmethod
def time_changed_event(time: QDate) -> None:
print(time.toString())
@staticmethod
def datetime_changed_event(datetime: QDate) -> None:
print(datetime.toString())
def button_event(self):
datetime = self.date_edit.dateTime().toString()
max_date = self.date_edit.maximumDate().toString()
min_date = self.date_edit.minimumDate().toString()
max_time = self.date_edit.maximumTime().toString()
min_time = self.date_edit.minimumTime().toString()
max_datetime = self.date_edit.maximumDateTime().toString()
min_datetime = self.date_edit.minimumDateTime().toString()
print(f'-' * 30, '\n',
f'当前日期时间:{datetime}', '\n',
f'最大日期:{max_date}', '\n',
f'最小日期:{min_date}', '\n',
f'最大时间:{max_time}', '\n',
f'最小时间:{min_time}', '\n',
f'最大日期时间:{max_datetime}', '\n',
f'最小日期时间:{min_datetime}', '\n',
f'-' * 30, sep='')
if __name__ == '__main__':
app = QApplication(sys.argv)
demo = DateTimeEditDemo()
demo.show()
sys.exit(app.exec_())
当触发dateChanged
,timeChanged
,dateTimeChanged
的时候会发射一个信号,可以直接使用槽函数接收。
如有侵权,请联系删除