【本实验内容】
1.GUI、PyQT5介绍
2.实现此次实验效果
【一 GUI、PyQt5介绍】
1.Python简介

2.GUI介绍
几个常用的Python GUI库:
(1)wxPython
(2)tkinter
(3)PyQt5

利用PyQt完成的项目效果展示:

【二 实现此次项目效果】

注意:后面代码都是在前面的基础上添加的;

>>>导入模块:

 from PyQt5.QtGui import *  # QtGui:对系统及窗口的操作
from PyQt5.QtCore import * # QtCore:包含一些核心的应用,例如时间模块等;
# QDesktopWidget:包含了屏幕的尺寸
from PyQt5.QtWidgets import QWidget,QDesktopWidget,QLCDNumber,QVBoxLayout,QApplication
import sys

>>>先编写一个闹钟程序的主窗口:

 #  “ADD1”
class MyTime(QWidget):
"""
面向对象的特点:封装、继承、多态---(类、方法、数据)
__init__是python语言里面的构造方法
"""
def __init__(self):
# 用于解决多重继承的问题
super().__init__()
self.initUI() # 绘制UI界面
def initUI(self):
# 窗口组件大小 250px像素 150
self.resize(250,150)
# self.move(300,300)
# 窗口标题:
self.setWindowTitle("创意小时钟-香")
self.show()
# “ADD2”
if __name__ == '__main__':
# 创建一个QT应用对象
app = QApplication(sys.argv)
m_time = MyTime()
sys.exit(app.exec_())
# app.exex_()

>>>  此时运行程序就可以初步构建一个轮廓了,效果如下:

>>>附截止目前的完整代码如下:

 from PyQt5.QtGui import *  # QtGui:对系统及窗口的操作
from PyQt5.QtCore import * # QtCore:包含一些核心的应用,例如时间模块等;
# QDesktopWidget:包含了屏幕的尺寸
from PyQt5.QtWidgets import QWidget, QDesktopWidget, QLCDNumber, QVBoxLayout, QApplication
import sys # “ADD1”
class MyTime(QWidget):
"""
面向对象的特点:封装、继承、多态---(类、方法、数据)
__init__是python语言里面的构造方法
""" def __init__(self):
# 用于解决多重继承的问题
super().__init__()
self.initUI() # 绘制UI界面 def initUI(self):
# 窗口组件大小 250px像素 150
self.resize(250, 150)
# self.move(300,300)
# 窗口标题:
self.setWindowTitle("创意小时钟-香")
self.show() # “ADD2”
if __name__ == '__main__':
# 创建一个QT应用对象
app = QApplication(sys.argv)
m_time = MyTime()
sys.exit(app.exec_())
# app.exex_()

窗口名字默认左上角,可以设置的;
>>>此时,时钟程序没有在正中心,因此进行继续编程解决这个问题:
         # “ADD2”
# 调用
self.move_center() # 在initUI()方法的self.show()语句前面增加 # “ADD1”
def move_center(self):
# 拿到主窗口的矩形
m_rect = self.frameGeometry()
# 获得整个屏幕的绝对值,从中得到屏幕的中心点
w_center_top = QDesktopWidget().availableGeometry().center()
m_rect.moveCenter(w_center_top)
# 从左向右边移动,直到屏幕中间的位置
self.move(m_rect.topLeft())

>>>现在运行,时钟程序窗口居中了:

>>>附截止目前的完整代码如下:

 from PyQt5.QtGui import *  # QtGui:对系统及窗口的操作
from PyQt5.QtCore import * # QtCore:包含一些核心的应用,例如时间模块等;
# QDesktopWidget:包含了屏幕的尺寸
from PyQt5.QtWidgets import QWidget, QDesktopWidget, QLCDNumber, QVBoxLayout, QApplication
import sys, time class MyTime(QWidget):
"""
面向对象的特点:封装、继承、多态---(类、方法、数据)
__init__是python语言里面的构造方法
""" def __init__(self):
# 用于解决多重继承的问题
super().__init__()
self.initUI()
# 绘制UI界面 def initUI(self):
# 窗口组件大小 250px 150
self.resize(250, 150)
# self.move(300,300)
# 窗口标题:
self.setWindowTitle("创意小时钟-香")
# 调用
self.move_center() # “ADD2”
self.show()
# “ADD1”
def move_center(self):
# 拿到主窗口的矩形
m_rect = self.frameGeometry()
# 获得整个屏幕的绝对值,从中得到屏幕的中心点
w_center_top = QDesktopWidget().availableGeometry().center()
m_rect.moveCenter(w_center_top)
# 从左向右边移动,直到屏幕中间的位置 if __name__ == '__main__':
# 创建一个QT应用对象
app = QApplication(sys.argv)
m_time = MyTime()
sys.exit(app.exec_())
# app.exex_()

>>>现在编程里面的LED数字时钟:

 import time  # “ADD1”:增加时间time模块

         # “ADD2 在initUI()方法的self.show()语句后面增加
self.lcd = QLCDNumber()
# 设置显示的个数
self.lcd.setDigitCount(10)
# 设置显示的模式为十进制的
self.lcd.setMode(QLCDNumber.Dec)
# 设置显示的模式为 平面模式
self.lcd.setSegmentStyle(QLCDNumber.Flat)
# 获取本地时间
self.lcd.display(time.strftime("%X", time.localtime()))
self.main_layout = QVBoxLayout()
# 将显示的组件添加到盒子布局里面
self.main_layout.addWidget(self.lcd)
# 设置组件在布局的中间位置
self.main_layout.setAlignment(Qt.AlignCenter)
# 设置给顶层布局
self.setLayout(self.main_layout)

>>>附截止目前的完整代码如下:

 from PyQt5.QtGui import *  # QtGui:对系统及窗口的操作
from PyQt5.QtCore import * # QtCore:包含一些核心的应用,例如时间模块等;
# QDesktopWidget:包含了屏幕的尺寸
from PyQt5.QtWidgets import QWidget, QDesktopWidget, QLCDNumber, QVBoxLayout, QApplication
import sys,time # “ADD1”:增加时间time模块 class MyTime(QWidget):
"""
面向对象的特点:封装、继承、多态---(类、方法、数据)
__init__是python语言里面的构造方法
""" def __init__(self):
# 用于解决多重继承的问题
super().__init__()
self.initUI() # 绘制UI界面 def initUI(self):
# 窗口组件大小 250px像素 150
self.resize(250, 150)
# self.move(300,300)
# 窗口标题:
self.setWindowTitle("创意小时钟-香")
# 调用
self.move_center()
self.show() # "ADD2
self.lcd = QLCDNumber()
# 设置显示的个数
self.lcd.setDigitCount(10)
# 设置显示的模式为十进制的
self.lcd.setMode(QLCDNumber.Dec)
# 设置显示的模式为 平面模式
self.lcd.setSegmentStyle(QLCDNumber.Flat)
# 获取本地时间
self.lcd.display(time.strftime("%X", time.localtime()))
self.main_layout = QVBoxLayout()
# 将显示的组件添加到盒子布局里面
self.main_layout.addWidget(self.lcd)
# 设置组件在布局的中间位置
self.main_layout.setAlignment(Qt.AlignCenter)
# 设置给顶层布局
self.setLayout(self.main_layout) def move_center(self):
# 拿到主窗口的矩形
m_rect = self.frameGeometry()
# 获得整个屏幕的绝对值,从中得到屏幕的中心点
w_center_top = QDesktopWidget().availableGeometry().center()
m_rect.moveCenter(w_center_top)
# 从左向右边移动,直到屏幕中间的位置
self.move(m_rect.topLeft()) if __name__ == '__main__':
# 创建一个QT应用对象
app = QApplication(sys.argv)
m_time = MyTime()
sys.exit(app.exec_())
# app.exex_()

>>>现在运行一下,查看结果,但是现在的问题是,时钟上是静态的?


现在解决这个时钟实时更新这个问题。

>>>ADD1 写一个有关定时器的“槽与信号”的函数:

     def init_timer(self):
# 提供了定时器信号和单出发定时器
self.timer = QTimer()
# 每间隔1秒就出发一次 timeout信号
self.timer.setInterval(1000)
self.timer.start() # 启动这个定时器
self.timer.timeout.connect(self.update_timer) # 信号和槽函数

>>>ADD2写一个输出本地实时时间的函数:

     def update_timer(self):
# 获取本地时间
self.lcd.display(time.strftime("%X", time.localtime()))
注意: 删除原来initUI()函数中的此行
# # 获取本地时间
# self.lcd.display(time.strftime("%X", time.localtime()))
>>>ADD3:调用“信号与槽函数”
         # ADD3:
self.init_timer()

>>>现在运行,结果时钟可以实时更新时间了:

>>>附截止目前的完整代码如下:

 from PyQt5.QtGui import *  # QtGui:对系统及窗口的操作
from PyQt5.QtCore import * # QtCore:包含一些核心的应用,例如时间模块等;
# QDesktopWidget:包含了屏幕的尺寸
from PyQt5.QtWidgets import QWidget, QDesktopWidget, QLCDNumber, QVBoxLayout, QApplication
import sys,time # “ADD1” class MyTime(QWidget):
"""
面向对象的特点:封装、继承、多态---(类、方法、数据)
__init__是python语言里面的构造方法
""" def __init__(self):
# 用于解决多重继承的问题
super().__init__()
self.initUI()
# ADD3:
self.init_timer()
# 绘制UI界面
# ADD1:
def init_timer(self):
# 提供了定时器信号和单出发定时器
self.timer = QTimer()
# 每间隔1秒就出发一次 timeout信号
self.timer.setInterval(1000)
self.timer.start() # 启动这个定时器
self.timer.timeout.connect(self.update_timer) # 信号和槽函数
# ADD2:
def update_timer(self):
# 获取本地时间
self.lcd.display(time.strftime("%X", time.localtime())) def initUI(self):
# 窗口组件大小 250px像素 150
self.resize(250, 150)
# self.move(300,300)
# 窗口标题:
self.setWindowTitle("创意小时钟-香")
# 调用
self.move_center()
self.show() self.lcd = QLCDNumber()
# 设置显示的个数
self.lcd.setDigitCount(10)
# 设置显示的模式为十进制的
self.lcd.setMode(QLCDNumber.Dec)
# 设置显示的模式为 平面模式
self.lcd.setSegmentStyle(QLCDNumber.Flat) # # 获取本地时间
# self.lcd.display(time.strftime("%X", time.localtime()))
self.main_layout = QVBoxLayout()
# 将显示的组件添加到盒子布局里面
self.main_layout.addWidget(self.lcd)
# 设置组件在布局的中间位置
self.main_layout.setAlignment(Qt.AlignCenter)
# 设置给顶层布局
self.setLayout(self.main_layout) def move_center(self):
# 拿到主窗口的矩形
m_rect = self.frameGeometry()
# 获得整个屏幕的绝对值,从中得到屏幕的中心点
w_center_top = QDesktopWidget().availableGeometry().center()
m_rect.moveCenter(w_center_top)
# 从左向右边移动,直到屏幕中间的位置
self.move(m_rect.topLeft()) if __name__ == '__main__':
# 创建一个QT应用对象
app = QApplication(sys.argv)
m_time = MyTime()
sys.exit(app.exec_())
# app.exex_()

发现,它的背景颜色太单调了,这时PyQt5中有一个“调色板”:
>>>ADD1:实例化一个调色板
         # 实例化一个调色板
self.main_pl = QPalette()
# 设置背景颜色为深黄色
# self.main_pl.setColor(QPalette.Background,Qt.darkRed)
self.main_pl.setColor(QPalette.Background, Qt.darkYellow)
# 设置窗体自动填充背景颜色
self.setAutoFillBackground(True)
self.setPalette(self.main_pl)

>>> 现在运行,查看结果:

>>>附截止目前的完整代码如下:

 from PyQt5.QtGui import *  # QtGui:对系统及窗口的操作
from PyQt5.QtCore import * # QtCore:包含一些核心的应用,例如时间模块等;
# QDesktopWidget:包含了屏幕的尺寸
from PyQt5.QtWidgets import QWidget, QDesktopWidget, QLCDNumber, QVBoxLayout, QApplication
import sys,time # “ADD1” class MyTime(QWidget):
"""
面向对象的特点:封装、继承、多态---(类、方法、数据)
__init__是python语言里面的构造方法
""" def __init__(self):
# 用于解决多重继承的问题
super().__init__()
self.initUI()
self.init_timer()
# 绘制UI界面 def init_timer(self):
# 提供了定时器信号和单出发定时器
self.timer = QTimer()
# 每间隔1秒就出发一次 timeout信号
self.timer.setInterval(1000)
self.timer.start() # 启动这个定时器
self.timer.timeout.connect(self.update_timer) # 信号和槽函数 def update_timer(self):
# 获取本地时间
self.lcd.display(time.strftime("%X", time.localtime())) def initUI(self):
# 窗口组件大小 250px像素 150
self.resize(250, 150)
# self.move(300,300)
# 窗口标题:
self.setWindowTitle("创意小时钟-香")
# 调用
self.move_center()
# ADD1:实例化一个调色板
# 实例化一个调色板
self.main_pl = QPalette()
# 设置背景颜色为深黄色
# self.main_pl.setColor(QPalette.Background,Qt.darkRed)
self.main_pl.setColor(QPalette.Background, Qt.darkYellow)
# 设置窗体自动填充背景颜色
self.setAutoFillBackground(True)
self.setPalette(self.main_pl) self.show()
self.lcd = QLCDNumber()
# 设置显示的个数
self.lcd.setDigitCount(10)
# 设置显示的模式为十进制的
self.lcd.setMode(QLCDNumber.Dec)
# 设置显示的模式为 平面模式
self.lcd.setSegmentStyle(QLCDNumber.Flat) # # 获取本地时间
# self.lcd.display(time.strftime("%X", time.localtime()))
self.main_layout = QVBoxLayout()
# 将显示的组件添加到盒子布局里面
self.main_layout.addWidget(self.lcd)
# 设置组件在布局的中间位置
self.main_layout.setAlignment(Qt.AlignCenter)
# 设置给顶层布局
self.setLayout(self.main_layout) def move_center(self):
# 拿到主窗口的矩形
m_rect = self.frameGeometry()
# 获得整个屏幕的绝对值,从中得到屏幕的中心点
w_center_top = QDesktopWidget().availableGeometry().center()
m_rect.moveCenter(w_center_top)
# 从左向右边移动,直到屏幕中间的位置
self.move(m_rect.topLeft()) if __name__ == '__main__':
# 创建一个QT应用对象
app = QApplication(sys.argv)
m_time = MyTime()
sys.exit(app.exec_())
# app.exex_()

>>>最后此项目的完整代码如下:

 from PyQt5.QtGui import *  # QtGui:对系统及窗口的操作
from PyQt5.QtCore import * # QtCore:包含一些核心的应用,例如时间模块等;
# QDesktopWidget:包含了屏幕的尺寸
from PyQt5.QtWidgets import QWidget,QDesktopWidget,QLCDNumber,QVBoxLayout,QApplication
import sys,time class MyTime(QWidget):
"""
面向对象的特点:封装、继承、多态---(类、方法、数据)
__init__是python语言里面的构造方法
"""
def __init__(self): # self指的是类实例对象的本身(PS:不是类本身)
# 用于解决多重继承的问题
super().__init__()
self.initUI()
self.init_timer()
def init_timer(self):
# 提供了定时器信号和单出发定时器
self.timer = QTimer()
# 每间隔1秒就出发一次 timeout信号
self.timer.setInterval(1000)
self.timer.start() # 启动这个定时器
self.timer.timeout.connect(self.update_timer) # 信号和槽函数
def update_timer(self):
# 获取本地时间
self.lcd.display(time.strftime("%X", time.localtime())) # 绘制UI界面
def initUI(self):
# 窗口组件大小 250px 150
self.resize(250,150)
# self.move(300,300)
# 窗口标题:
self.setWindowTitle("创意小时钟-香")
# 调用
self.move_center() # 实例化一个调色板
self.main_pl = QPalette()
# 设置背景颜色为深黄色
# self.main_pl.setColor(QPalette.Background,Qt.darkRed)
self.main_pl.setColor(QPalette.Background, Qt.darkYellow)
# 设置窗体自动填充背景颜色
self.setAutoFillBackground(True)
self.setPalette(self.main_pl) # 字体颜色的设置:这里有问题:
# self.main_pl = QPalette()
# self.main_pl.setColor(QPalette.Normal, QPalette.windowText,Qt.darkBlue)
# self.setAutoFillBackground(True)
# self.setPalette(self.main_pl) # 显示布局
self.show() self.lcd = QLCDNumber()
# 设置显示的个数
self.lcd.setDigitCount(10)
# 设置显示的模式为十进制的
self.lcd.setMode(QLCDNumber.Dec)
# 设置显示的模式为 平面模式
self.lcd.setSegmentStyle(QLCDNumber.Flat)
# 实例化盒子布局
self.main_layout = QVBoxLayout()
# 将显示的组件添加到盒子布局里面
self.main_layout.addWidget(self.lcd)
# 设置组件在布局的中间位置
self.main_layout.setAlignment(Qt.AlignCenter)
# 设置给顶层布局
self.setLayout(self.main_layout) def move_center(self):
# 拿到主窗口的矩形
m_rect = self.frameGeometry()
# 获得整个屏幕的绝对值,从中得到屏幕的中心点
w_center_top = QDesktopWidget().availableGeometry().center()
m_rect.moveCenter(w_center_top)
# 从左向右边移动,直到屏幕中间的位置
self.move(m_rect.topLeft())
if __name__ == '__main__':
# 创建一个QT应用对象
app = QApplication(sys.argv)
m_time = MyTime()
sys.exit(app.exec_())
# app.exex_()

The end!

**************************************************************************************************
                                                        Good lucky to you
**************************************************************************************************

【python】实现一个python编程的小时钟!的更多相关文章

  1. 一听就懂:用Python做一个超简单的小游戏

    写它会用到 while 循环random 模块if 语句输入输出函数

  2. python 搭建一个http服务的小例子

    一.创建Server 1.Dos 命令 python -m BaseHTTPServer [port] 默认端口是8000, 2.Python 脚本启动 #coding:utf-8 ''' Creat ...

  3. Python编写一个Python脚本

    我想要一个可以为我的所有重要文件创建备份的程序.(下面测试环境为python2.7) 1.backup_ver1.py #!/usr/bin/python import os import time ...

  4. 【Python】一个python实例:给重要的文件创建备份.摘自crossin-python简明教程

    问题:写一个可以为所有重要文件创建备份的程序 考虑:源路径和目标路径各是什么;所有重要文件-有哪些;备份文件格式是什么;定期备份的话,备份文件名称如何规定等等.(ps,我自己只想到一个路径和名称) 程 ...

  5. Python——第一个python程序helloworld

    安装了Python的环境之后,就是编写Python的代码了. 首先,我们来写一个简单的“hello world” 新建一个空白的txt文本,将后缀改为.py 改了后缀之后即变为Python程序的图标 ...

  6. Python 第一个Python项目Hello,Python 学习之路(二)

    print("Hello,Python")

  7. Python ->> 第一个Python程序

    #coding:utf-8 #print 'input your name, please' #name = raw_input('请输入你的名字:'.decode('utf-8').encode(' ...

  8. Python基础入门-实现猜数字小游戏

    今天呢,我们来通过前面学过的一些知识点来完成一个猜数字大小的游戏程序设计.那么呢,一般人写代码直接上来就干,没有分析,这样的做法是没有产出的,除非你是大牛,今天呢,我会把我学习编程的思路分享给大家,我 ...

  9. python socket编程---从使用Python开发一个Socket示例说到开发者的思维和习惯问题

    今天主要说的是一个开发者的思维和习惯问题. 思维包括编程的思维和解决一个具体问题的分析思维,分析思路,分析方法,甚至是分析工具. 无论是好习惯还是不好的习惯,都是在者一天一天的思维中形成的.那些不好的 ...

随机推荐

  1. 2018 Wannafly summer camp Day3--Shopping

    Shopping 描述 题目描述: 你要买n件物品,其中有一些是凳子. 商场正在举行促销活动,如果购物车中有至少一个凳子,那么你可以半价购买这个购物车中最贵的一个物品. 你有m辆购物车,请最小化你的花 ...

  2. c++cmb

    #include<windows.h> #include<bits/stdc++.h> using namespace std; ]; int main() { printf( ...

  3. mysql查看锁等信息SQL

    查看锁等信息,包括锁信息: select "HOLD:",ph.id h_processid,trh.trx_id h_trx_id,trh.trx_started h_start ...

  4. 搭建docker registry (htpasswd 认证)

    1,拉取docker registry 镜像 docker pull registry 2,创建证书存放目录 mkdir -p /home/registry 3,生成CA证书Edit your /et ...

  5. 精干货! Java 后端程序员 1 年工作经验总结

    一.引言   毕业已经一年有余,这一年里特别感谢技术管理人员的器重,以及同事的帮忙,学到了不少 东西.这一年里走过一些弯路,也碰到一些难题,也受到过做为一名开发却经常为系统维护 和发布当救火队员的苦恼 ...

  6. Hive初识(一)

    LOAD DATA语句 一般来说,在SQL创建表后,我们就可以使用INSERT语句插入数据.但在Hive中,可以使用LOAD DATA语句来插入数据. LOAD DATA [LOCAL] INPATH ...

  7. Python的scrapy之爬取boss直聘网站

    在我们的项目中,单单分析一个51job网站的工作职位可能爬取结果不太理想,所以我又爬取了boss直聘网的工作,不过boss直聘的网站一次只能展示300个职位,所以我们一次也只能爬取300个职位. jo ...

  8. WHERE条件中or与union引起的全表扫描的问题

    说起数据库的SQL语句执行效率的问题,就不得不提where条件语句中的or(逻辑或)引起的全表扫描问题,从而导致效率下降. 在以往绝大多数的资料中,大多数人的建议是使用 union 代替 or ,以解 ...

  9. 集成运放输入电压范围指标参数Uicmax,Uidmax

    图中Uicmax最大共模输入电压:是运放能正常工作下的最大输入电压: Uidmax最大差模输入电压:是运放要损坏的最大输入电压

  10. 关于 js 对象 转 字符串 和 深拷贝 的探讨

    随着更多语言的支持 **json** 作为数据传输和存储的媒体,已经非常成熟且应用广泛.却存在致命硬伤,不携带 **对象方法** .在数据传输和存储中,这是恰当的和合理的. 但是在更多的应用场景中,又 ...