親手教你用Python打造一款摸魚(yú)倒計(jì)時(shí)界面
前言
前段時(shí)間在微博看到一段摸魚(yú)人的倒計(jì)時(shí)模板,感覺(jué)還挺有趣的。
于是我用了一小時(shí)的時(shí)間寫(xiě)了個(gè)頁(yè)面出來(lái) 摸魚(yú)辦地址 (當(dāng)然是摸魚(yú)的時(shí)間啦)。
模板是這樣的:
摸魚(yú)辦公室?
你好,摸魚(yú)人,工作再累,一定不要忘記摸魚(yú)哦 ! 有事沒(méi)事起身去茶水間去廊道去天臺(tái)走走,別老在工位上坐著。多喝點(diǎn)水,錢(qián)是老板的,但命是自己的 !
距離 周末 放假還有 2 天
距離 元旦 放假還有 3 天
距離 過(guò)年 放假還有 34 天
距離 清明節(jié) 放假還有 97 天
距離 勞動(dòng)節(jié) 放假還有 123 天
距離 端午節(jié) 放假還有 156 天
距離 中秋節(jié) 放假還有 255 天
距離 國(guó)慶節(jié) 放假還有 276 天
- 由于前端是單頁(yè)面服務(wù),直接擼一個(gè)原始的
html
網(wǎng)頁(yè)就行。 FastAPI
對(duì)于異步請(qǐng)求是一把好手、更輕、性能更佳。- 掛上一層
Nginx
讓它看起來(lái)像那么回事兒。
實(shí)現(xiàn)過(guò)程
- 首先要知道、除了靜態(tài)文字之外的比如當(dāng)前日期、距離節(jié)日放假的天數(shù)等都是動(dòng)態(tài)返回的,我需要使用 Jinja2 模板進(jìn)行動(dòng)態(tài)綁定。
- 我應(yīng)該把重點(diǎn)放在時(shí)間的處理上。
- 而且在這個(gè)模板中,有陽(yáng)歷的節(jié)日,也是陰歷的節(jié)日,我需要轉(zhuǎn)換。
初始化一個(gè) FastAPI 對(duì)象并聲明靜態(tài)頁(yè)面的模板目錄 (Jinja2Templates)
*- 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
這個(gè)庫(kù)、主要用于陰歷
和陽(yáng)歷
之間的相互轉(zhuǎn)換。用法如下
today = datetime.date.today() print(today.year, today.month, today.day) print("大年時(shí)間: ", lunar_date(today.year+1, 1, 1).to_datetime().date()) print("端午時(shí)間: ", lunar_date(today.year, 5, 5).to_datetime().date()) print("中秋時(shí)間: ", lunar_date(today.year, 8, 15).to_datetime().date()) print("元旦時(shí)間: ", f"{today.year+1}-01-01") print("清明時(shí)間: ", f"{today.year}-04-05") print("勞動(dòng)時(shí)間: ", f"{today.year}-05-01") print("國(guó)慶時(shí)間: ", f"{today.year}-10-01")
我們可以梳理一下:
計(jì)算距離大年、元旦
的天數(shù)時(shí),要在年份上+1
計(jì)算距離其他節(jié)日
的天數(shù)時(shí),要判斷天數(shù)差是否小于0
,如果是,則年份需要+1
,因?yàn)橐呀?jīng)過(guò)去的節(jié)日對(duì)此沒(méi)有意義
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().date() - today).days distance_8_15 = (lunar_date(today.year, 8, 15).to_datetime().date() - today).days distance_8_15 = distance_8_15 if distance_8_15 > 0 else ( lunar_date(today.year + 1, 8, 15).to_datetime().date() - today).days distance_year = (datetime.datetime.strptime(f"{today.year + 1}-01-01", "%Y-%m-%d").date() - today).days distance_4_5 = (datetime.datetime.strptime(f"{today.year}-04-05", "%Y-%m-%d").date() - today).days distance_4_5 = distance_4_5 if distance_4_5 > 0 else ( datetime.datetime.strptime(f"{today.year + 1}-04-05", "%Y-%m-%d").date() - today).days distance_5_1 = (datetime.datetime.strptime(f"{today.year}-05-01", "%Y-%m-%d").date() - today).days distance_5_1 = distance_5_1 if distance_5_1 > 0 else ( datetime.datetime.strptime(f"{today.year + 1}-05-01", "%Y-%m-%d").date() - today).days distance_10_1 = (datetime.datetime.strptime(f"{today.year}-10-01", "%Y-%m-%d").date() - today).days distance_10_1 = distance_10_1 if distance_10_1 > 0 else ( datetime.datetime.strptime(f"{today.year + 1}-10-01", "%Y-%m-%d").date() - today).days
怎么樣? 我的命名足夠瘋狂吧。
接下來(lái)需要計(jì)算一下距離周末
的天數(shù)。
def get_week_day(date): week_day_dict = { 0: '星期一', 1: '星期二', 2: '星期三', 3: '星期四', 4: '星期五', 5: '星期六', 6: '星期天', } day = date.weekday() return week_day_dict[day] week_day_ = get_week_day(today) print(f"今天是: {week_day_}") # 先獲取今天是星期幾
按照每周5
個(gè)工作日計(jì)算,今天距離周末的天數(shù)就是
5 - today.weekday() # today.weekday() 今天距離周末
現(xiàn)在將所有的數(shù)據(jù)組裝起來(lái)
time_ = [ {"v_": distance_year, "title": "元旦"}, # 距離元旦 {"v_": distance_big_year, "title": "過(guò)年"}, # 距離過(guò)年 {"v_": distance_4_5, "title": "清明節(jié)"}, # 距離清明 {"v_": distance_5_1, "title": "勞動(dòng)節(jié)"}, # 距離勞動(dòng) {"v_": distance_5_5, "title": "端午節(jié)"}, # 距離端午 {"v_": distance_8_15, "title": "中秋節(jié)"}, # 距離中秋 {"v_": distance_10_1, "title": "國(guó)慶節(jié)"}, # 距離國(guó)慶 ]
至于為什么是List
而不是Dict
,那是我需要做一個(gè)根據(jù)距離天數(shù)的排序
,讓最先放假的節(jié)日放于最前面, 這樣看起來(lái)會(huì)舒服得多。
time_ = sorted(time_, key=lambda x: x['v_'], reverse=False)
接下來(lái)要寫(xiě)一個(gè) 路由,將數(shù)據(jù)傳入到html
頁(yè)面中去。
@app.get("/", response_class=HTMLResponse) async def readme(request: Request): return templates.TemplateResponse("readme.html", {"request": request, "time_": time_, "now_": now_, "week_day_": week_day_})
來(lái)看一下完整的代碼 (main.py):
# -*- 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=f"/docs", openapi_url=f"/openapi.json" ) templates = Jinja2Templates(directory="templates") today = datetime.date.today() # print(today.year, today.month, today.day) # print("大年時(shí)間: ", lunar_date(today.year+1, 1, 1).to_datetime().date()) # print("端午時(shí)間: ", lunar_date(today.year, 5, 5).to_datetime().date()) # print("中秋時(shí)間: ", lunar_date(today.year, 8, 15).to_datetime().date()) # print("元旦時(shí)間: ", f"{today.year+1}-01-01") # print("清明時(shí)間: ", f"{today.year+1}-04-05") # print("勞動(dòng)時(shí)間: ", f"{today.year+1}-05-01") # print("國(guó)慶時(shí)間: ", f"{today.year+1}-10-01") 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().date() - today).days distance_8_15 = (lunar_date(today.year, 8, 15).to_datetime().date() - today).days distance_8_15 = distance_8_15 if distance_8_15 > 0 else ( lunar_date(today.year + 1, 8, 15).to_datetime().date() - today).days distance_year = (datetime.datetime.strptime(f"{today.year + 1}-01-01", "%Y-%m-%d").date() - today).days distance_4_5 = (datetime.datetime.strptime(f"{today.year}-04-05", "%Y-%m-%d").date() - today).days distance_4_5 = distance_4_5 if distance_4_5 > 0 else ( datetime.datetime.strptime(f"{today.year + 1}-04-05", "%Y-%m-%d").date() - today).days distance_5_1 = (datetime.datetime.strptime(f"{today.year}-05-01", "%Y-%m-%d").date() - today).days distance_5_1 = distance_5_1 if distance_5_1 > 0 else ( datetime.datetime.strptime(f"{today.year + 1}-05-01", "%Y-%m-%d").date() - today).days distance_10_1 = (datetime.datetime.strptime(f"{today.year}-10-01", "%Y-%m-%d").date() - today).days distance_10_1 = distance_10_1 if distance_10_1 > 0 else ( datetime.datetime.strptime(f"{today.year + 1}-10-01", "%Y-%m-%d").date() - today).days def get_week_day(date): week_day_dict = { 0: '星期一', 1: '星期二', 2: '星期三', 3: '星期四', 4: '星期五', 5: '星期六', 6: '星期天', } day = date.weekday() return week_day_dict[day] # print("距離大年: ", distance_big_year) # print("距離端午: ", distance_5_5) # print("距離中秋: ", distance_8_15) # print("距離元旦: ", distance_year) # print("距離清明: ", distance_4_5) # print("距離勞動(dòng): ", distance_5_1) # print("距離國(guó)慶: ", distance_10_1) # print("距離周末: ", 5 - today.weekday()) now_ = f"{today.year}年{today.month}月{today.day}日" week_day_ = get_week_day(today) time_ = [ {"v_": 5 - 1 - today.weekday(), "title": "周末"}, # 距離周末 {"v_": distance_year, "title": "元旦"}, # 距離元旦 {"v_": distance_big_year, "title": "過(guò)年"}, # 距離過(guò)年 {"v_": distance_4_5, "title": "清明節(jié)"}, # 距離清明 {"v_": distance_5_1, "title": "勞動(dòng)節(jié)"}, # 距離勞動(dòng) {"v_": distance_5_5, "title": "端午節(jié)"}, # 距離端午 {"v_": distance_8_15, "title": "中秋節(jié)"}, # 距離中秋 {"v_": distance_10_1, "title": "國(guó)慶節(jié)"}, # 距離國(guó)慶 ] time_ = sorted(time_, key=lambda x: x['v_'], reverse=False) @app.get("/", response_class=HTMLResponse) async def readme(request: Request): return templates.TemplateResponse("readme.html", {"request": request, "time_": time_, "now_": now_, "week_day_": week_day_}) if __name__ == '__main__': import uvicorn uvicorn.run(app='main:app', host="0.0.0.0", port=8080, reload=True)
最后就到了html
頁(yè)面部分了,來(lái)看一下主要的傳值。
<center> 【摸魚(yú)辦公室】今天是 {{ now_ }} {{ week_day_ }} <br><br> {% for v_ in time_ %} <p>距離 {{ v_.title }} 放假還有 {{ v_.v_ }} 天</p> {% else %} <p>沒(méi)有任何值</p> {% endfor %} </center>
這樣整個(gè)的路由構(gòu)造和頁(yè)面編寫(xiě)就算是完成了。
最后通過(guò)Nginx
部署到我的站點(diǎn)上。
摸魚(yú)辦預(yù)覽地址
代碼已經(jīng)上傳至摸魚(yú)辦:
https://github.com/PY-GZKY/moyu
到此這篇關(guān)于手把手教你使用Python打造一款摸魚(yú)倒計(jì)時(shí)界面的文章就介紹到這了,更多相關(guān)Python摸魚(yú)倒計(jì)時(shí)界面內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- python實(shí)現(xiàn)倒計(jì)時(shí)的示例
- python實(shí)現(xiàn)倒計(jì)時(shí)小工具
- python實(shí)現(xiàn)的簡(jiǎn)單窗口倒計(jì)時(shí)界面實(shí)例
- python 實(shí)現(xiàn)倒計(jì)時(shí)功能(gui界面)
- python實(shí)現(xiàn)簡(jiǎn)單倒計(jì)時(shí)功能
- python實(shí)現(xiàn)七段數(shù)碼管和倒計(jì)時(shí)效果
- python使用tkinter實(shí)現(xiàn)屏幕中間倒計(jì)時(shí)
- python實(shí)現(xiàn)windows倒計(jì)時(shí)鎖屏功能
- python基于tkinter制作下班倒計(jì)時(shí)工具
- 基于Python實(shí)現(xiàn)倒計(jì)時(shí)工具
相關(guān)文章
python存儲(chǔ)16bit和32bit圖像的實(shí)例
今天小編就為大家分享一篇python存儲(chǔ)16bit和32bit圖像的實(shí)例,具有的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-12-12Python判斷一個(gè)文件夾內(nèi)哪些文件是圖片的實(shí)例
今天小編就為大家分享一篇Python判斷一個(gè)文件夾內(nèi)哪些文件是圖片的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-12-12python中Ansible模塊的Playbook的具體使用
這篇文章主要介紹了python中Ansible模塊的Playbook的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05使用 Django Highcharts 實(shí)現(xiàn)數(shù)據(jù)可視化過(guò)程解析
這篇文章主要介紹了使用 Django Highcharts 實(shí)現(xiàn)數(shù)據(jù)可視化過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07用Python PIL實(shí)現(xiàn)幾個(gè)簡(jiǎn)單的圖片特效
這篇文章主要介紹了用Python PIL實(shí)現(xiàn)幾個(gè)簡(jiǎn)單的圖片特效,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01python庫(kù)Celery異步發(fā)送電子郵件定時(shí)生成報(bào)告實(shí)戰(zhàn)示例
這篇文章主要介紹了python庫(kù)Celery異步發(fā)送電子郵件定時(shí)生成報(bào)告實(shí)戰(zhàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01Python制作簡(jiǎn)易版小工具之計(jì)算天數(shù)的實(shí)現(xiàn)思路
這篇文章主要介紹了Python制作簡(jiǎn)易版小工具之計(jì)算天數(shù)的實(shí)現(xiàn)思路,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02Python自動(dòng)化開(kāi)發(fā)學(xué)習(xí)之三級(jí)菜單制作
這篇文章主要為大家詳細(xì)介紹了Python自動(dòng)化開(kāi)發(fā)學(xué)習(xí)之三級(jí)菜單的制作方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07