继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

使用pyqt5的日期控件做一个小日历方便查看

OverWrite_235
关注TA
已关注
手记 138
粉丝 10
获赞 65

日历的制作比较简单,因为pyqt5已经自带了相关的日期控件,只需要明白如何调用再加上比较个性化的功能,这个日历的小控件就制作完成了。

file

日历实现代码量不多,需要可直接执行的源码在文末获取下载链接。

file

在制作过程中使用到的python模块包说明:

from PyQt5.QtWidgets import *  # 窗口组件

from PyQt5.QtCore import *  # 核心组件、日历组件就是在这个库

import sys  # 操作系统处理库

在小日历的制作过程中只使用了一个槽函数,就是将当前选中的日历时间进行字符串的格式化以后再显示到下面的标签控件上。只需要一句代码就可以实现了。

def calender_show(self):
        '''
        当前日历展示的槽函数
        :return:
        '''
        selected = self.calender_.selectedDate()
        self.current_date.setText('您当前选中的日期是:{}'.format(selected.toString("yyyy-MM-dd dddd")))

在每个 GUI 的应用中代码量比较多的还是 UI 界面的使用上面。下面就是相关控件的初始化和显示过程。


    def init_ui(self):
        '''
        日历UI界面函数
        :return:
        '''
        self.setWindowTitle("我的小日历")  # 设置标题

        vbox = QVBoxLayout()  # 创建垂直布局

        '''创建日历控件对象'''
        self.calender_ = QCalendarWidget()
        self.calender_.setGridVisible(True)  # 设置日期控件使用网格布局
        self.calender_.setMinimumDate(QDate(1970, 1, 1))  # 设置最小日期
        self.calender_.setMaximumDate(QDate(3200, 1, 1))  # 设置最大日期
        self.calender_.setFirstDayOfWeek(Qt.Monday)  # 设置星期一为每周的第一天
        self.calender_.clicked[QDate].connect(self.calender_show)

        vbox.addWidget(self.calender_)  # 将日历控件加入垂直布局

        self.current_date = QLabel()
        self.calender_show()

        vbox.addWidget(self.current_date)  # 将显示标签加入布局

        self.setLayout(vbox)  # 将垂直布局作为主布局加入
打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP