🕒【开源工具】 PyQt5打造高颜值时间控制器|💻系统时间管理神器开发全攻略
🌈 个人主页:创客白泽 - CSDN博客
🔥 系列专栏:🐍《Python开源项目实战》
💡 热爱不止于代码,热情源自每一个灵感闪现的夜晚。愿以开源之火,点亮前行之路。
🐋 希望大家多多支持,我们一起进步!
👍 🎉如果文章对你有帮助的话,欢迎 点赞 👍🏻 评论 💬 收藏 ⭐️ 加关注+💗分享给更多人哦
🌟 一、概述:当时间管理遇上现代UI
在日常开发中,我们经常需要精确控制系统时间,但Windows自带的时间设置工具实在太简陋了!😫 今天我要分享的是用PyQt5开发的高颜值时间控制器,它不仅颜值在线,还具备:
- 🎨 现代化Fluent Design界面
- ⚡ 实时时间显示(精确到秒)
- ✏️ 可视化时间修改(带日历控件)
- 🌐 NTP网络时间同步模拟
- 🛡️ 智能权限检测(自动识别管理员权限)
💡 技术亮点:本项目的界面设计参考了Windows 11的Fluent UI设计规范,采用QSS实现深度样式定制,是学习PyQt5现代化开发的绝佳案例!
🛠️ 二、功能全景:六大核心模块解析
2.1 实时时钟模块
class ModernTerminalLabel(QLabel):
"""🔄 动态时钟标签"""
def __init__(self):
self.setStyleSheet("""
background: qlineargradient(x1:0, y1:0, x2:1, y2:1,
stop:0 #3498db, stop:1 #2c3e50);
border-radius: 10px;
color: white;
padding: 15px;
""")
▲ 自定义渐变效果时钟标签▲
2.2 时间设置模块
🛠️ 功能特点:
- 📅 集成QDateTimeEdit控件
- 🗓️ 带弹出式日历选择
- ⚠️ 自动检测管理员权限
2.3 NTP同步模块
🌍 支持服务器列表:
pool.ntp.org
(默认)time.google.com
(谷歌)time.windows.com
(微软)ntp.aliyun.com
(阿里云)
🎥 三、效果展示:眼见为实
3.1 主界面(Light模式)
3.2 帮助页面展示
3.3 时间同步演示
🧩 四、手把手实现教程
4.1 环境准备
pip install PyQt5==5.15.9 pywin32
4.2 核心类结构
4.3 关键代码解析
时间修改功能
def change_datetime(self):
try:
# 🛡️ 权限检查
if not ctypes.windll.shell32.IsUserAnAdmin():
self.show_error("💢 需要管理员权限!")
return
# ⏱️ 设置系统时间
ctypes.windll.kernel32.SetLocalTime(byref(time_struct))
self.show_success("✅ 时间修改成功!")
except Exception as e:
self.show_error(f"❌ 错误:{
str(e)}")
NTP同步动画
def update_sync_status(self, step):
steps = [
"🛰️ 正在连接服务器...",
"⏳ 获取时间数据...",
"⚙️ 校准系统中...",
"🎉 同步完成!"
]
self.status_label.setText(steps[step])
📥 五、源码获取与进阶改造
5.1 完整项目下载
import sys
import ctypes
import platform
from datetime import datetime
from PyQt5.QtWidgets import (QApplication, QMainWindow, QWidget, QVBoxLayout,
QHBoxLayout, QLabel, QDateTimeEdit, QPushButton,
QMessageBox, QTabWidget, QLineEdit, QComboBox,
QFormLayout, QFrame, QSizePolicy, QSpacerItem)
from PyQt5.QtCore import QDateTime, Qt, QTimer
from PyQt5.QtGui import QFont, QColor, QPalette, QFontDatabase, QIcon
class ModernTerminalLabel(QLabel):
"""现代化终端风格标签"""
def __init__(self, text, font_size=14, bold=False):
super().__init__(text)
self.setAlignment(Qt.AlignCenter)
self.setSizePolicy(QSizePolicy.Expanding, QSizePolicy.Fixed)
# 字体选择优先级列表
preferred_fonts = ["Segoe UI", "Arial", "Helvetica", "Microsoft YaHei", "PingFang SC"]
font_db = QFontDatabase()
available_fonts = font_db.families()
# 选择第一个可用的字体
selected_font = "Arial" # 默认回退字体
for font_name in preferred_fonts:
if font_name in available_fonts:
selected_font = font_name
break
font = QFont(selected_font, font_size)
font.setBold(bold)
self.setFont(font)
self.setStyleSheet("color: #2c3e50;")
class ModernButton(QPushButton):
"""现代化按钮"""
def __init__(self, text, icon=None, parent=None):
super().__init__(text, parent)
self.setCursor(Qt.PointingHandCursor)
self.setMinimumHeight(42)
if icon:
self.setIcon(QIcon.fromTheme