【本实验内容】
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. iOS之一些实用的Demo

    图像浏览及处理 FLAnimatedImage - gif播放处理的工具. CLImageEditor - 超强的图片编辑库,快速帮你实现旋转,防缩,滤镜等等一系列麻烦的事情. ios-image-f ...

  2. MySQL里面的锁

    MySQL里面的锁可以分为:全局锁,表级锁,行级锁. 一.全局锁:对整个数据库实例加锁.MySQL提供加全局读锁的方法:Flush tables with read lock(FTWRL)这个命令可以 ...

  3. HTML中footer固定在页面底部的若干种方法

    <div class="header"><div class="main"></div></div> <d ...

  4. tidb损坏tikv节点怎么恢复集群

    tikv节点宕机(机器再起不来),或者数据节点被rm -rf 掉了怎么办 正常情况下tikv节点down掉了.此时不要去执行store delete  store_id .数据一般可以正常访问,但是如 ...

  5. XML文档处理

    1)CDATA部分用<![CDATA[和]]>来限定其界限,它们是字符数据的一种特殊形式,可用使用它们来囊括那些含有<.>,&之类字符的字符串,而不必将它们解释为标记例 ...

  6. ECSHOP和SHOPEX快递单号查询申通插件V8.6专版

    发布ECSHOP说明: ECSHOP快递物流单号查询插件特色 本ECSHOP快递物流单号跟踪插件提供国内外近2000家快递物流订单单号查询服务例如申通快递.顺丰快递.圆通快递.EMS快递.汇通快递.宅 ...

  7. JavaSE 第二次学习随笔(二)

    循环结构中的多层嵌套跳出 targeta: for(int i = 0; i < 100; i++){ for (int j = 0; j < 100; j++) { if(i + j = ...

  8. 查看ubuntu版本号命令

    1.uname -a 查看内核版本号 2.cat /etc/issue 查看ubuntu版本号 3.sudo lsb_release -a 查看ubuntu版本号

  9. haproxy + keepalived 实现高可用负载均衡集群

    1. 首先准备两台tomcat机器,作为集群的单点server. 第一台: 1)tomcat,需要Java的支持,所以同样要安装Java环境. 安装非常简单. tar xf  jdk-7u65-lin ...

  10. R语言学习笔记(五):零碎知识点(11-15)

    11--which.min(), which.max()和which() which(x, arr.ind = FALSE, useNames = TRUE) x 是一个向量或者数组,可以是NA,但会 ...