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

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

参考: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. 7.29 DFS总结

    7.29   黄昏时刻 (一) 全排列 建模: 给了数字n 代表从1-n 个数全排列 思路: 1. 输入n,如果n值为‘0’,则退出程序 2. vis[i] 保存 是否对第i个数字进行访问 3. df ...

  2. linux中的"32位"与"64位"

    linux内核学习之三:linux中的"32位"与"64位" 在通用PC领域,不论是windows还是linux界,我们都会经常听到"32位" ...

  3. N个骰子的点数和的概率分布

    程序设计思路: 假设有n个骰子,关键是需要统计每个点数出现的次数.首先分析第一个骰子点数和有1到6的点数,计算出1到6的每种点数 的次数,并将结果用一个数组pos1记录.然后分析有两个骰子时, 点数为 ...

  4. Atomic变量和Thread局部变量

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

  5. 微信移动支付V3开发详细教程服务端采用.net mvc webapi(C#)

    转自:http://www.kwstu.com/ArticleView/netmvc_201511132050268716 最近开发手机app需要实现移动支付功能,由于考虑支付安全将微信支付生成签名写 ...

  6. css中display的属性解析

    display 属性规定元素应该生成的框的类型. 他有很多属性值,见如下表格: none 此元素不会被显示. block 此元素将显示为块级元素,此元素前后会带有换行符. inline 默认.此元素会 ...

  7. spring.net AOP配置基础

    在第一篇中,我们用配置代理工厂的方式实现了面向切面记日志的功能.非常便捷的实现了AOP,但当我们需要对多个切入点配置通知的时候就需要声明多个代理工厂,这样导致配置文件内容过多,配置过程也很繁琐.spr ...

  8. iOS 开发之Target-action模式

    Target-action:目标-动作模式,它贯穿于iOS开发始终.但是对于初学者来说,还是被这种模式搞得一头雾水. 其实Target-action模式很简单,就是当某个事件发生时,调用那个对象中的那 ...

  9. JAVA多线程经典问题 -- 生产者 消费者 同步队列实现方法

    在JAVASE5 中的java.util.concurrent.BlockingQueue支持,BlockingQueue是一个接口但是我们通常可以使用LinkedBlockingQueue,它是一个 ...

  10. 改ext界面

    以前的ext界面         被我给换成了         为的是响应整个系统平台的颜色色调---绿色,还得科技搭配蓝色,我可是想破了脑袋,才想到这种蓝绿搭配,领导们不知道怎么想的