基于Python绘制一个摸鱼倒计时界面

前端时间推出了一个摸鱼APP,这篇文章将为大家介绍基于Python绘制一个摸鱼倒计时界面,文中的示例代码讲解详细,感兴趣的可以学习一下。编程学习资料免费白嫖领取

前言

前段时间在微博看到一段摸鱼人的倒计时模板,感觉还挺有趣的。

于是我用了一小时的时间写了个页面出来 摸鱼办地址 (当然是摸鱼的时间啦)。

模板是这样的:

摸鱼办公室 🐟

【摸鱼办公室】今天是 2021-11-30 星期二

你好,摸鱼人,工作再累,一定不要忘记摸鱼哦 ! 有事没事起身去茶水间去廊道去天台走走,别老在工位上坐着。多喝点水,钱是老板的,但命是自己的 !

🐟 距离 周末 放假还有 2 天

🐟 距离 元旦 放假还有 3 天

🐟 距离 过年 放假还有 34 天

🐟 距离 清明节 放假还有 97 天

🐟 距离 劳动节 放假还有 123 天

🐟 距离 端午节 放假还有 156 天

🐟 距离 中秋节 放假还有 255 天

🐟 距离 国庆节 放假还有 276 天

  • 由于前端是单页面服务,直接撸一个原始的 html 网页就行。
  • FastAPI 对于异步请求是一把好手、更轻、性能更佳。
  • 挂上一层 Nginx 让它看起来像那么回事儿。

实现过程

首先要知道、除了静态文字之外的比如当前日期、距离节日放假的天数等都是动态返回的,我需要使用 Jinja2 模板进行动态绑定。

我应该把重点放在时间的处理上。

而且在这个模板中,有阳历的节日,也是阴历的节日,我需要转换。

初始化一个 FastAPI 对象并声明静态页面的模板目录 (Jinja2Templates)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

# -*- coding: utf-8 -*-

import datetime

from fastapi import FastAPI, Request

from fastapi.responses import HTMLResponse

from fastapi.templating import Jinja2Templates

from zhdate import ZhDate as lunar_date

  

app = FastAPI(

    debug=False,

    title="My API",

    docs_url="/docs",

    openapi_url=f"/openapi.json"

)

  

templates = Jinja2Templates(directory="templates")

可以看到的是我用到了 zhdate 这个库、主要用于阴历和阳历之间的相互转换。用法如下

1

2

3

4

5

6

7

8

9

today = datetime.date.today()

print(today.year, today.month, today.day)

print("大年时间: ", lunar_date(today.year+1, 1, 1).to_datetime().date())

print("端午时间: ", lunar_date(today.year, 5, 5).to_datetime().date())

print("中秋时间: ", lunar_date(today.year, 8, 15).to_datetime().date())

print("元旦时间: ", f"{today.year+1}-01-01")

print("清明时间: ", f"{today.year}-04-05")

print("劳动时间: ", f"{today.year}-05-01")

print("国庆时间: ", f"{today.year}-10-01")

我们可以梳理一下:

计算距离 大年、元旦 的天数时,要在年份上 +1

计算距离 其他节日 的天数时,要判断天数差是否小于 0,如果是,则年份需要 +1,因为已经过去的节日对此没有意义

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

distance_big_year = (lunar_date(today.year + 1, 1, 1).to_datetime().date() - today).days

  

distance_5_5 = (lunar_date(today.year, 5, 5).to_datetime().date() - today).days

distance_5_5 = distance_5_5 if distance_5_5 > 0 else (

        lunar_date(today.year + 1, 5, 5).to_datetime().

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
首先,需要安装 Python 的 GUI 库 tkinter,可以使用以下命令: ```python pip install tkinter ``` 然后,我们可以开始实现绘制七段数码管的功能。以下是代码实现: ```python import tkinter as tk class SevenSegment(tk.Canvas): def __init__(self, master=None, cnf={}, **kw): super().__init__(master=None, cnf={}, **kw) self.configure(width=60, height=100, bg='black', highlightthickness=0) self.draw_segments([0, 0, 0, 0, 0, 0, 0]) def draw_segments(self, segments): self.delete(tk.ALL) self.create_polygon(5, 5, 55, 5, 50, 10, 10, 10, fill='red' if segments[0] else 'grey', outline='') self.create_polygon(5, 5, 10, 10, 10, 50, 5, 55, fill='red' if segments[1] else 'grey', outline='') self.create_polygon(55, 5, 50, 10, 50, 50, 55, 55, fill='red' if segments[2] else 'grey', outline='') self.create_polygon(5, 55, 10, 50, 10, 90, 5, 95, fill='red' if segments[3] else 'grey', outline='') self.create_polygon(55, 55, 50, 50, 50, 90, 55, 95, fill='red' if segments[4] else 'grey', outline='') self.create_polygon(5, 95, 10, 90, 50, 90, 55, 95, fill='red' if segments[5] else 'grey', outline='') self.create_polygon(10, 50, 50, 50, 55, 55, 10, 55, fill='red' if segments[6] else 'grey', outline='') ``` 这个类实现了一个七段数码管的绘制,接下来我们实现秒表倒计时的功能。 ```python import time class Stopwatch: def __init__(self, master): self.master = master self.seven_segment = SevenSegment(master, bg='black') self.seven_segment.grid(row=0, column=0, columnspan=3, padx=10, pady=10) self.start_button = tk.Button(master, text='Start', command=self.start) self.start_button.grid(row=1, column=0, padx=10, pady=10) self.stop_button = tk.Button(master, text='Stop', command=self.stop, state='disabled') self.stop_button.grid(row=1, column=1, padx=10, pady=10) self.reset_button = tk.Button(master, text='Reset', command=self.reset, state='disabled') self.reset_button.grid(row=1, column=2, padx=10, pady=10) self.running = False self.count = 0 self.start_time = 0 self.update() def start(self): self.running = True self.start_button.config(state='disabled') self.stop_button.config(state='normal') self.reset_button.config(state='disabled') self.start_time = time.time() def stop(self): self.running = False self.start_button.config(state='normal') self.stop_button.config(state='disabled') self.reset_button.config(state='normal') def reset(self): self.count = 0 self.update() def update(self): if self.running: self.count = int(time.time() - self.start_time) if self.count < 0: self.count = 0 self.running = False self.start_button.config(state='normal') self.stop_button.config(state='disabled') self.reset_button.config(state='normal') else: self.master.after(100, self.update) else: self.master.after(100, self.update) minutes = self.count // 60 seconds = self.count % 60 self.seven_segment.draw_segments([minutes // 10, minutes % 10, seconds // 10, seconds % 10, 0, 0, 0]) ``` 这个类实现了秒表倒计时的功能,并且生成了一个 GUI 界面,包含“Start”、“Stop”、“Reset”按钮和一个七段数码管。接下来我们可以将这个类实例化,生成一个秒表倒计时的窗口。 ```python root = tk.Tk() stopwatch = Stopwatch(root) root.mainloop() ``` 完整代码如下: ```python import tkinter as tk import time class SevenSegment(tk.Canvas): def __init__(self, master=None, cnf={}, **kw): super().__init__(master=None, cnf={}, **kw) self.configure(width=60, height=100, bg='black', highlightthickness=0) self.draw_segments([0, 0, 0, 0, 0, 0, 0]) def draw_segments(self, segments): self.delete(tk.ALL) self.create_polygon(5, 5, 55, 5, 50, 10, 10, 10, fill='red' if segments[0] else 'grey', outline='') self.create_polygon(5, 5, 10, 10, 10, 50, 5, 55, fill='red' if segments[1] else 'grey', outline='') self.create_polygon(55, 5, 50, 10, 50, 50, 55, 55, fill='red' if segments[2] else 'grey', outline='') self.create_polygon(5, 55, 10, 50, 10, 90, 5, 95, fill='red' if segments[3] else 'grey', outline='') self.create_polygon(55, 55, 50, 50, 50, 90, 55, 95, fill='red' if segments[4] else 'grey', outline='') self.create_polygon(5, 95, 10, 90, 50, 90, 55, 95, fill='red' if segments[5] else 'grey', outline='') self.create_polygon(10, 50, 50, 50, 55, 55, 10, 55, fill='red' if segments[6] else 'grey', outline='') class Stopwatch: def __init__(self, master): self.master = master self.seven_segment = SevenSegment(master, bg='black') self.seven_segment.grid(row=0, column=0, columnspan=3, padx=10, pady=10) self.start_button = tk.Button(master, text='Start', command=self.start) self.start_button.grid(row=1, column=0, padx=10, pady=10) self.stop_button = tk.Button(master, text='Stop', command=self.stop, state='disabled') self.stop_button.grid(row=1, column=1, padx=10, pady=10) self.reset_button = tk.Button(master, text='Reset', command=self.reset, state='disabled') self.reset_button.grid(row=1, column=2, padx=10, pady=10) self.running = False self.count = 0 self.start_time = 0 self.update() def start(self): self.running = True self.start_button.config(state='disabled') self.stop_button.config(state='normal') self.reset_button.config(state='disabled') self.start_time = time.time() def stop(self): self.running = False self.start_button.config(state='normal') self.stop_button.config(state='disabled') self.reset_button.config(state='normal') def reset(self): self.count = 0 self.update() def update(self): if self.running: self.count = int(time.time() - self.start_time) if self.count < 0: self.count = 0 self.running = False self.start_button.config(state='normal') self.stop_button.config(state='disabled') self.reset_button.config(state='normal') else: self.master.after(100, self.update) else: self.master.after(100, self.update) minutes = self.count // 60 seconds = self.count % 60 self.seven_segment.draw_segments([minutes // 10, minutes % 10, seconds // 10, seconds % 10, 0, 0, 0]) root = tk.Tk() stopwatch = Stopwatch(root) root.mainloop() ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值