从昨天到现在,一直在研究这个看起来超级简单的时钟。界面非常简洁大方。

虽然是简单,可是这个对齐的问题还是把我整得一塌糊涂。谁叫作者不解释清楚的。

参考:http://bbs.fishc.com/thread-77638-1-1.html

接下来,我们一步步解决。

----------------------------------------------------------------------------------------------------------------

步骤1

注意。这里是换行打印才能打印出这种图形的,这个字典储存的是列表,为啥储存的是列表呢?因为待会

一个数字,我们是要分上中下三个部分打印的。

这里的元素要尽可能对齐,因为这个程序最麻烦的就是要整齐的输出。第一个/位置0元素的笔画统一居中。

以0为例,位置0(一横)除了1和4之外,在其它数字都是给包围起来的,所以两边的空格其实是留给竖的!!!

 lcd = {
0: [" _ ", "| |", "|_|"],
1: [" ", " |", " |"],
2: [" _ ", " _|", "|_ "],
3: [" _ ", " _|", " _|"],
4: [" ", "|_|", " |"],
5: [" _ ", "|_ ", " _|"],
6: [" _ ", "|_ ", "|_|"],
7: [" _ ", " |", " |"],
8: [" _ ", "|_|", "|_|"],
9: [" _ ", "|_|", " _|"]
} for num in lcd:
for i in lcd[num]:
print i

如果输出的是这种整整齐齐的数字的话(代码是纵向输出的),说明我们千辛万苦输入的列表元素是正确的。

步骤2

    接上面的代码,完整版在下面。

 # coding: utf-8                                                             

 import time

 # 分别把时,分,秒,拆分成上中下三个部分并
# 分别存储到一个空列表中(empty) def num2lcd(time):
et = ["", "", ""]
shiwei = time / 10
gewei = time % 10 for i in range(0, 3):
et[i] = lcd[shiwei][i] + lcd[gewei][i] return et # time.localtime()是输出当前日期的元组
# t.tm_hour是时,t.tm_min是分钟
# 这个函数最关键的部分是把之前分开的时,
# 分,秒的列表元素集合到一个列表中,最后统一打印出来。 def clock():
t = time.localtime()
h = num2lcd(t.tm_hour)
m = num2lcd(t.tm_min)
s = num2lcd(t.tm_sec) output = [h[0] + m[0] + s[0], h[1] + m[1] + s[1], h[2] + m[2] + s[2]]
return output

注意,这里的时间显示能否对齐完全取决于lcd字典是否对齐,每个值前面和后面的空格数量一定要控制好

---------------------------------------------------------------------------------------------------------------------------

 # coding: utf-8                                                                                   2016/12/8

 import os, time

 # 这里在上面的基础上,每个列表的元素后面加
# 多一个空格,让数字之间显示更美观 lcd = {
0: [" _ ", "| | ", "|_| "],
1: [" ", " | ", " | "],
2: [" _ ", " _| ", "|_ "],
3: [" _ ", " _| ", " _| "],
4: [" ", "|_| ", " | "],
5: [" _ ", "|_ ", " _| "],
6: [" _ ", "|_ ", "|_| "],
7: [" _ ", " | ", " | "],
8: [" _ ", "|_| ", "|_| "],
9: [" _ ", "|_| ", " _| "],
} # 分别把时,分,秒,拆分成上中下三个部分并
# 分别存储到一个空列表中(empty) def num2lcd(time):
et = ["", "", ""]
shiwei = time / 10
gewei = time % 10 for i in range(0, 3):
et[i] = lcd[shiwei][i] + lcd[gewei][i] return et # time.localtime()是输出当前日期的元组
# t.tm_hour是时,t.tm_min是分钟
# 这个函数最关键的部分是把之前分开的时,
# 分,秒的列表元素集合到一个列表中,最后统一打印出来。 def clock():
t = time.localtime()
h = num2lcd(t.tm_hour)
m = num2lcd(t.tm_min)
s = num2lcd(t.tm_sec) output = [h[0] + " " + m[0] + " " + s[0], h[1] + "." + m[1] + "." + s[1], h[2] + "." + m[2] + "." + s[2]]
return output while True:
for i in clock():
print i
time.sleep(1)
os.system("cls")

时钟完整版

由于在时和分,分和秒之间加了冒号,而每个时h[0]和分m[0],分m[0]和秒s[0]之间距离是一定的,

由于冒号自身占用1个空格,所以后面的会变成这样。因此要在h[0]的m[0],m[0]和s[0]之间加上空格。

 output = [h[0] + " " + m[0] + " " + s[0], h[1] + "." + m[1] + "." + s[1], h[2] + "." + m[2] + "." + s[2]]

----------------------------------------------------------------------------------------------------------------------------

秒表的同理类似。这里就不再介绍了,直接附上代码。

# coding: utf-8

import os, sys, time

lcd = {
0: [" _ ", "| | ", "|_| "],
1: [" ", " | ", " | "],
2: [" _ ", " _| ", "|_ "],
3: [" _ ", " _| ", " _| "],
4: [" ", "|_| ", " | "],
5: [" _ ", "|_ ", " _| "],
6: [" _ ", "|_ ", "|_| "],
7: [" _ ", " | ", " | "],
8: [" _ ", "|_| ", "|_| "],
9: [" _ ", "|_| ", " _| "]
} def num2lcd(time):
et = ["", "", ""]
shiwei = time / 10
gewei = time % 10 for i in range(0, 3):
et[i] = lcd[shiwei][i] + lcd[gewei][i] return et def clock(minute, second):
m = num2lcd(minute)
s = num2lcd(second) output = [m[0] + " " + s[0], m[1] + "." + s[1], m[2] + "." + s[2]] return output sec = 0
while True:
sec += 1
m = sec / 60
s = sec % 60 for i in clock(m, s):
print i time.sleep(1)
os.system("cls")

一般来说,当需要输出时间时,用求余符号%来求出分和秒是比较简便的。或者大家也可

以看看下面这一种。是用for循环在1和60之间循环递增的。择自己喜欢的一种即可。

 # coding: utf-8

 import os, sys, time

 lcd = {
0: [" _ ", "| | ", "|_| "],
1: [" ", " | ", " | "],
2: [" _ ", " _| ", "|_ "],
3: [" _ ", " _| ", " _| "],
4: [" ", "|_| ", " | "],
5: [" _ ", "|_ ", " _| "],
6: [" _ ", "|_ ", "|_| "],
7: [" _ ", " | ", " | "],
8: [" _ ", "|_| ", "|_| "],
9: [" _ ", "|_| ", " _| "]
} def num2lcd(time):
et = ["", "", ""]
shiwei = time / 10
gewei = time % 10 for i in range(0, 3):
et[i] = lcd[shiwei][i] + lcd[gewei][i] return et def clock(minute, second):
m = num2lcd(minute)
s = num2lcd(second) output = [m[0] + " " + s[0], m[1] + "." + s[1], m[2] + "." + s[2]] return output minute = 0
while True:
for sec in range(1, 61):
if sec == 60:
sec = 0 # 记得到了第60秒时秒要清零哦
minute += 1 # 同时分钟要 +1 for i in clock(minute, sec):
print i time.sleep(1)
os.system("cls")

lcd秒表

【Time系列五】个性时钟与秒表升级版的更多相关文章

  1. Keil MDK STM32系列(五) 使用STM32CubeMX创建项目基础结构

    Keil MDK STM32系列 Keil MDK STM32系列(一) 基于标准外设库SPL的STM32F103开发 Keil MDK STM32系列(二) 基于标准外设库SPL的STM32F401 ...

  2. CSS 魔法系列:纯 CSS 绘制各种图形《系列五》

    我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多比人想象不到的效果.特别是随着 CSS3 的广泛使用,更多新奇的 CSS 作品涌现出来. ...

  3. Netty4.x中文教程系列(五)编解码器Codec

    Netty4.x中文教程系列(五)编解码器Codec 上一篇文章详细解释了ChannelHandler的相关构架设计,版本和设计逻辑变更等等. 这篇文章主要在于讲述Handler里面的Codec,也就 ...

  4. WCF编程系列(五)元数据

    WCF编程系列(五)元数据   示例一中我们使用了scvutil命令自动生成了服务的客户端代理类: svcutil http://localhost:8000/?wsdl /o:FirstServic ...

  5. JVM系列五:JVM监测&工具

    JVM系列五:JVM监测&工具[整理中]  http://www.cnblogs.com/redcreen/archive/2011/05/09/2040977.html 前几篇篇文章介绍了介 ...

  6. SQL Server 2008空间数据应用系列五:数据表中使用空间数据类型

    原文:SQL Server 2008空间数据应用系列五:数据表中使用空间数据类型 友情提示,您阅读本篇博文的先决条件如下: 1.本文示例基于Microsoft SQL Server 2008 R2调测 ...

  7. VSTO之旅系列(五):创建Outlook解决方案

    原文:VSTO之旅系列(五):创建Outlook解决方案 本专题概要 引言 Outlook对象模型 自定义Outlook窗体 小结 一.引言 在上一个专题中,为大家简单介绍了下如何创建Word解决方案 ...

  8. 系列五AnkhSvn

    原文:系列五AnkhSvn AnkhSvn介绍 AnkhSVN是一款在VS中管理Subversion的插件,您可以在VS中轻松的提交.更新.添加文件,而不用在命令行或资源管理器中提交.而且该插件属于开 ...

  9. java多线程系列(五)---synchronized ReentrantLock volatile Atomic 原理分析

    java多线程系列(五)---synchronized ReentrantLock volatile Atomic 原理分析 前言:如有不正确的地方,还望指正. 目录 认识cpu.核心与线程 java ...

随机推荐

  1. JAVA学习:多态

    多态:可以理解为事物存在的多种体现形态.   人:男人,女人 动物:猫,狗. 猫 x = new 猫(); 动物 x = new 猫()   1,多态的体现 父类的引用指向了自己的子类对象. 父类的引 ...

  2. Linux环境进程间通信(二): 信号(上)

    linux下进程间通信的几种主要手段: 管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允 ...

  3. C++数据结构之二叉查找树(BST)

    C++数据结构之二叉查找树(BST) 二分查找法在算法家族大类中属于“分治法”,二分查找的过程比较简单,代码见我的另一篇日志,戳这里!因二分查找所涉及的有序表是一个向量,若有插入和删除结点的操作,则维 ...

  4. DropDownList单选与多选下拉框

    一.单选DropDownList传值 1.添加界面的DropDownList显示值问题 (1)在方法内添加ViewData的方法: var ad = new UnitsRepository(); Vi ...

  5. Atomic变量和Thread局部变量

    Atomic变量和Thread局部变量 前面我们已经讲过如何让对象具有Thread安全性,让它们能够在同一时间在两个或以上的Thread中使用.Thread的安全性在多线程设计中非常重要,因为race ...

  6. .NET接口和类 反射的差异性发现

    1 背景 在项目中使用反射,反射出某类型的所有属性(Property)和对应的属性值.起初为了性能考虑在模块首次加载就反射类型的所有属性并将其存入字典.根据一般的编程规范——基于接口编程,所以首次传入 ...

  7. Call U

    Communication - 02.Call U App层 从大拇哥Click CallButton开始手机便已明白,主人这是要打电话.当然,你可以选择直接拨号,也可以通过ContactList,或 ...

  8. struts2中token的令牌机制

    通常在普通的操作当中,我们不需要处理重复提交的,而且有很多方法来防止重复提交.比如在登陆过程中,通过使用redirect,可以让用户登陆之上重定向到后台首页界面,当用户刷新界面时就不会触发重复提交了. ...

  9. EditPlus配置C环境

    一, 目标 1, 编译 ---- 根据编写的 .c 文件, 生成 .exe 文件 2, 运行 ---- 运行 生成的 .exe文件 3, 清理 ---- 删除 生成的 .exe文件 二, 环境 1,  ...

  10. [设计模式-创建型]工厂方法(Factory Method)

    概括 名称 Factory Method 结构 动机 定义一个用于创建对象的接口,让子类决定实例化哪一个类.Factory Method 使一个类的实例化延迟到其子类. 适用性 当一个类不知道它所必 ...