【本实验内容】
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. JavaScript--动态添加元素

    在网页中,使用JavaScript动态创建元素的方式有三种: 1.document.write() 2.Element.innerHTML 3.document.createElement() 在上述 ...

  2. java的动态验证码单线设计

    1.java的动态验证码我这里将介绍两种方法: 一:根据java本身提供的一种验证码的写法,这种呢只限于大家了解就可以了,因为java自带的模式编写的在实际开发中是没有意义的,所以只供学习一下就可以了 ...

  3. vue服务端渲染按需引入mint

    vue服务器渲染按需引入mint-ui 1.修改.babelrc文件,在.babelrc文件中plugins数组中添加 { "presets": [["es2015&qu ...

  4. jQuery 打气球小游戏 点击气球爆炸效果

    最近在学习前端,看到偶尔看到前端小游戏,就想自己写一个小游戏,奈何水平有限,只能写打气球这种简单的,所有的气球都是动态生成的,气球的颜色也是随机的 html部分 <div class=" ...

  5. 微信小程序INC自增自减MUL自乘问题

    今天使用到微信小程序云开发中的数据库自增字段问题出现了错误 Uncaught (in promise) ReferenceError: _ is not defined 官方给出的INC方法文档 db ...

  6. ELK的简述安装

    一.ElasticSearch集群的安装及其配置 https://www.cnblogs.com/gentle-awen/p/10000801.html 可视化x-pack安装: https://ww ...

  7. python三大神器之生成器

    生成器Generator: 本质:迭代器(所以自带了__iter__方法和__next__方法,不需要我们去实现) 特点:惰性运算,开发者自定义 在python中有三种方法来获取生成器: 1.通过生成 ...

  8. 前端学习之HTML基础

    要点: 理解HTTP请求响应模式及通信规范 HTML的各种标签和常用标签 CSS是用于样式渲染和定位布局 JS将HTML动态化 jquery是JS的高级封装 理解HTTP请求响应模式及通信规范 HTT ...

  9. 初识python 面向对象

    what the f**k!!这个知识点学不好的最大元凶就是,我还单身??? python基础(四): 面向对象的三个特点: 封装,继承,多态 类: 对象是面向对象编程的核心,在使用对象的过程中,为了 ...

  10. php curl 登陆百度贴吧(经历记录)

    这两天,因为公司需要,所以研究了一下百度文库的登陆方案.因为账号是购买的,只有一部分cookie值,所以不能通过正常的渠道登陆,所以只有通过curl模拟直接进行后台登陆.那么,问题来了.按照人家说的, ...