当前位置: 首页 > wzjs >正文

怎样建设网站论文网站seo提升

怎样建设网站论文,网站seo提升,中国科技成就作文800字,天津网站建设设计费用PyQt5实用小工具:工作时长计算器工具开发全解析 🌈 个人主页:创客白泽 - CSDN博客 🔥 系列专栏:🐍《Python开源项目实战》 💡 热爱不止于代码,热情源自每一个灵感闪现的夜晚。愿以开…

PyQt5实用小工具:工作时长计算器工具开发全解析

在这里插入图片描述
请添加图片描述

🌈 个人主页:创客白泽 - CSDN博客
🔥 系列专栏:🐍《Python开源项目实战》
💡 热爱不止于代码,热情源自每一个灵感闪现的夜晚。愿以开源之火,点亮前行之路。
👍 如果觉得这篇文章有帮助,欢迎您一键三连,分享给更多人哦

请添加图片描述
在这里插入图片描述


摘要:
在日常工作和项目管理中,准确计算工作时长是非常重要的。本文将深入讲解如何利用PyQt5开发一个简单易用的“工作时长计算器”桌面应用,涵盖设计思路、功能实现、UI布局、核心代码解析及打包细节。文中配有示例代码和界面截图,帮助读者快速掌握PyQt5实战技能。


目录

  • 概述
  • 功能介绍
  • 界面展示
  • 软件使用步骤说明
  • 代码详解
    • 窗口初始化与布局
    • 工作时长计算核心逻辑
    • 剪贴板复制与状态提示
    • 窗口置顶功能
  • 源码下载
  • 总结与展望

概述

随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长。虽然市面上有众多复杂的考勤软件,但对于简单的时间计算需求,一个轻量级且界面友好的桌面应用更具实用性和便利性。

本文介绍的“工作时长计算器”基于Python的PyQt5库开发,体积小巧,界面简洁,支持用户输入上下班时间,一键计算出当天工作时长,并可将结果复制到剪贴板,方便粘贴到日报、考勤系统或聊天工具中。


功能介绍

  • 输入上下班时间(HH:MM格式)
  • 自动计算并显示工作时长,支持跨天工作时段
  • 复制工作时长到剪贴板,一键分享
  • 窗口置顶功能,方便随时查看和操作
  • 友好的错误提示,避免无效时间格式输入
  • 自定义窗口图标与样式美化,提升用户体验

界面展示

1. 主界面

在这里插入图片描述

图1:工作时长计算器主界面,简洁明了,支持键盘输入与按钮操作

2. 计算结果显示与复制反馈

在这里插入图片描述

图2:计算完成后显示时长,点击复制按钮弹出提示


软件使用步骤说明

  1. 启动程序:运行python work_time_calculator.py
  2. 输入上班时间:如08:30
  3. 输入下班时间:如17:45
  4. 点击“计算工作时长”按钮,显示工作时长,例如08:15
  5. 点击“复制时长”按钮,将结果复制到剪贴板,方便粘贴
  6. 勾选“窗口置顶”,保持程序界面在最前端
  7. 如输入格式错误,弹出错误提示框,请按提示修改时间格式

代码详解

窗口初始化与布局

class WorkTimeCalculator(QWidget):def __init__(self):super().__init__()self.setWindowTitle("工作时长计算器")self.setFixedSize(320, 380)# 设置窗口图标icon_path = self.resource_path("time.ico")self.setWindowIcon(QIcon(icon_path))# 窗口置顶属性self.setWindowFlags(self.windowFlags() | Qt.WindowStaysOnTopHint)self.duration_str = ""self.init_ui()
  • QWidget是PyQt中最基础的窗口类。
  • 固定窗口大小,保证UI布局一致性。
  • 使用自定义图标美化程序。
  • 通过Qt.WindowStaysOnTopHint保持窗口置顶。

UI组件布局采用QVBoxLayout垂直堆叠控件,样式使用QFontsetStyleSheet增强视觉体验。


工作时长计算核心逻辑

def calculate_time(self):start_text = self.input_start.text().strip()end_text = self.input_end.text().strip()try:start_time = datetime.strptime(start_text, "%H:%M")end_time = datetime.strptime(end_text, "%H:%M")if end_time < start_time:end_time = end_time.replace(day=start_time.day + 1)duration = end_time - start_timetotal_minutes = duration.seconds // 60hours = total_minutes // 60minutes = total_minutes % 60self.duration_str = f"{hours:02}:{minutes:02}"self.result_label.setText(f"🧮 工作时长:{self.duration_str}")except ValueError:QMessageBox.warning(self, "❌ 错误", "请输入有效时间格式,如 09:00")
  • 使用datetime.strptime解析输入时间。
  • 处理跨天工作(如夜班,结束时间小于开始时间时,自动视为第二天)。
  • 计算时间差,转换成小时和分钟。
  • 结果格式化为HH:MM,更新界面标签显示。
  • 异常处理避免程序崩溃,弹出错误提示框。

剪贴板复制与状态提示

def copy_duration(self):if self.duration_str:QApplication.clipboard().setText(self.duration_str)self.show_status_message(f"⏱️ 时长 {self.duration_str} 已复制到剪贴板", 1200)else:QMessageBox.warning(self, "⚠️ 无数据", "请先计算工作时长")def show_status_message(self, message, timeout=1000):self.status_label.setText(message)self.status_label.setVisible(True)QTimer.singleShot(timeout, lambda: self.status_label.setVisible(False))
  • 复制时长字符串到系统剪贴板。
  • 使用状态栏显示短暂提示,提升用户交互体验。
  • 未计算前复制操作给出警告提示。

窗口置顶功能

def toggle_topmost(self, state):if state == Qt.Checked:self.setWindowFlags(self.windowFlags() | Qt.WindowStaysOnTopHint)else:self.setWindowFlags(self.windowFlags() & ~Qt.WindowStaysOnTopHint)self.show()
  • 通过QCheckBox切换窗口置顶属性。
  • 动态刷新窗口状态,确保设置生效。

源码下载

import sys
import os
from PyQt5.QtWidgets import (QApplication, QWidget, QLabel, QLineEdit, QPushButton,QVBoxLayout, QMessageBox, QCheckBox
)
from PyQt5.QtGui import QFont, QIcon
from PyQt5.QtCore import Qt, QTimer
from datetime import datetimeclass WorkTimeCalculator(QWidget):def __init__(self):super().__init__()self.setWindowTitle("工作时长计算器")self.setFixedSize(320, 380)# 设置窗口图标icon_path = self.resource_path("time.ico")self.setWindowIcon(QIcon(icon_path))self.setWindowFlags(self.windowFlags() | Qt.WindowStaysOnTopHint)self.duration_str = ""self.init_ui()def init_ui(self):font = QFont("Arial", 12)self.label_start = QLabel("👨‍💼 上班时间 (HH:MM):")self.label_start.setFont(font)self.input_start = QLineEdit()self.input_start.setPlaceholderText("如:08:30")self.input_start.setFont(font)self.input_start.setStyleSheet("""QLineEdit {border: 2px solid #ccc;border-radius: 10px;padding: 6px 10px;}""")self.label_end = QLabel("🏠 下班时间 (HH:MM):")self.label_end.setFont(font)self.input_end = QLineEdit()self.input_end.setPlaceholderText("如:17:45")self.input_end.setFont(font)self.input_end.setStyleSheet("""QLineEdit {border: 2px solid #ccc;border-radius: 10px;padding: 6px 10px;}""")self.button_calc = QPushButton("✅ 计算工作时长")self.button_calc.setFont(font)self.button_calc.setStyleSheet("""QPushButton {background-color: #4CAF50;color: white;border: none;border-radius: 10px;padding: 8px;}QPushButton:hover {background-color: #45a049;}QPushButton:pressed {background-color: #3e8e41;}""")self.button_calc.clicked.connect(self.calculate_time)self.result_label = QLabel("🧮 工作时长:--:--")self.result_label.setFont(QFont("Arial", 13, QFont.Bold))self.copy_button = QPushButton("📋 复制时长")self.copy_button.setFont(font)self.copy_button.setStyleSheet("""QPushButton {background-color: #2196F3;color: white;border: none;border-radius: 10px;padding: 8px;}QPushButton:hover {background-color: #1e88e5;}QPushButton:pressed {background-color: #1976d2;}""")self.copy_button.clicked.connect(self.copy_duration)self.checkbox_topmost = QCheckBox("📌 窗口置顶")self.checkbox_topmost.setFont(font)self.checkbox_topmost.setChecked(True)self.checkbox_topmost.stateChanged.connect(self.toggle_topmost)self.status_label = QLabel("")self.status_label.setFont(QFont("Arial", 10))self.status_label.setStyleSheet("color: white; background-color: #444; padding: 4px; border-radius: 4px;")self.status_label.setAlignment(Qt.AlignCenter)self.status_label.setVisible(False)layout = QVBoxLayout()layout.setSpacing(8)layout.setContentsMargins(16, 16, 16, 16)layout.addWidget(self.label_start)layout.addWidget(self.input_start)layout.addWidget(self.label_end)layout.addWidget(self.input_end)layout.addWidget(self.button_calc)layout.addWidget(self.result_label)layout.addWidget(self.copy_button)layout.addWidget(self.checkbox_topmost)layout.addWidget(self.status_label)self.setLayout(layout)def calculate_time(self):start_text = self.input_start.text().strip()end_text = self.input_end.text().strip()try:start_time = datetime.strptime(start_text, "%H:%M")end_time = datetime.strptime(end_text, "%H:%M")if end_time < start_time:end_time = end_time.replace(day=start_time.day + 1)duration = end_time - start_timetotal_minutes = duration.seconds // 60hours = total_minutes // 60minutes = total_minutes % 60self.duration_str = f"{hours:02}:{minutes:02}"self.result_label.setText(f"🧮 工作时长:{self.duration_str}")except ValueError:QMessageBox.warning(self, "❌ 错误", "请输入有效时间格式,如 09:00")def copy_duration(self):if self.duration_str:QApplication.clipboard().setText(self.duration_str)self.show_status_message(f"⏱️ 时长 {self.duration_str} 已复制到剪贴板", 1200)else:QMessageBox.warning(self, "⚠️ 无数据", "请先计算工作时长")def show_status_message(self, message, timeout=1000):self.status_label.setText(message)self.status_label.setVisible(True)QTimer.singleShot(timeout, lambda: self.status_label.setVisible(False))def toggle_topmost(self, state):if state == Qt.Checked:self.setWindowFlags(self.windowFlags() | Qt.WindowStaysOnTopHint)else:self.setWindowFlags(self.windowFlags() & ~Qt.WindowStaysOnTopHint)self.show()def resource_path(self, relative_path):"""解决打包后资源路径问题"""if hasattr(sys, '_MEIPASS'):return os.path.join(sys._MEIPASS, relative_path)return os.path.join(os.path.abspath("."), relative_path)if __name__ == "__main__":app = QApplication(sys.argv)app.setStyle("Fusion")window = WorkTimeCalculator()window.show()sys.exit(app.exec_())

总结与展望

本文详细介绍了基于PyQt5的“工作时长计算器”的开发过程,涵盖了窗口设计、时间处理逻辑、交互细节及用户体验优化。该工具简单实用,适合日常办公人员快速统计工作时长。

未来可以拓展的功能有:

  • 支持批量导入多天时间记录,自动生成日报
  • 增加午休、加班等特殊时段计算支持
  • 导出统计报表(Excel、PDF等格式)
  • 美化UI,支持多语言切换和主题模式

欢迎大家试用源码,提出宝贵意见,共同完善!

http://www.dtcms.com/wzjs/58219.html

相关文章:

  • 重庆网站建设论文知名网站排名
  • 免费开源建站教学网站河南seo快速排名
  • 肇东市建设局网站bt磁力搜索
  • 工信部网站 备案时间网站关键词优化排名
  • 深圳品牌设计公司介绍麒麟seo外推软件
  • 哪个公司做网站建设好企业网站建设服务
  • 驻马店网站建设维护什么时候友情链接
  • 外贸网站怎么做才好淘宝运营培训班去哪里学
  • 团购网站做二级域名网络营销的应用
  • 做网站那家比较好seo排名优化点击软件有哪些
  • 什么是网站开发设计与实现微信广告
  • 苹果手机做任务网站网上如何做广告
  • 怎么增加网站关键词库广告公司的业务范围
  • dede网站301怎么做电商培训机构推荐
  • 上海做公司网站多少钱百度推广费用报价单
  • 哈尔滨网站建设市场网站免费网站免费
  • 咨询聊城网站建设网络营销的未来6个发展趋势
  • it培训机构怎么样淮安网站seo
  • 常熟网站建设哪家好运用搜索引擎营销的案例
  • 禅城区网站建设公司外链管理
  • 山东网站建设和游戏开发的公司排名网站维护一般怎么做
  • 端口映射 wordpress怎么seo网站关键词优化
  • 合肥网站设计公数据分析师证书
  • 教务处网站建设要求怎么建网站赚钱
  • 大英县住房和城乡建设局网站广东seo外包服务
  • 阜蒙县建设镇网站腾讯新闻发布平台
  • 上海网页制作服务商广州seo招聘
  • 南山的网站设计广告代发平台
  • 律师微网站建设网站关键词快速排名工具
  • 网站开发与网页后台开发天津网站快速排名提升