本篇內(nèi)容介紹了“如何用Python制作我的核酸檢測日歷”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
成都創(chuàng)新互聯(lián)自2013年創(chuàng)立以來,先為成都等服務(wù)建站,成都等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為成都企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
核酸檢測記錄能查到的最早時間范圍是一個月,以前的檢測記錄沒有提前保存,所以先用8月份的數(shù)據(jù)制作日歷。
查詢8月份的檢測記錄,錄入到代碼中。
# coding=utf-8 from datetime import datetime # 核酸檢測數(shù)據(jù),1表示當(dāng)天做了核酸,0表示當(dāng)天未做核酸 my_nucleic = { 'date': [datetime.strftime(datetime(2022, 8, i+1), '%Y-%m-%d') for i in range(31)], 'nucleic': [1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] }
如果當(dāng)天做了核酸,用1表示,如果當(dāng)天未做核酸,用0表示。
8月的日期使用Python標(biāo)準(zhǔn)庫datetime生成。
本文使用Python庫openpyxl在excel表格中生成日歷。
import openpyxl # 創(chuàng)建一個workbook對象,而且會在workbook中至少創(chuàng)建一個表worksheet wb = openpyxl.Workbook() # 獲取當(dāng)前活躍的worksheet,默認(rèn)就是第一個worksheet ws = wb.active
openpyxl是Python中用于讀寫excel文件的庫,pip install openpyxl安裝即可使用。
from openpyxl.styles import PatternFill, Font, Alignment, Border, Side def init_sheet(ws): for r in range(100): for c in range(100): ws.cell(row=r+1, column=c+1).fill = PatternFill('solid', fgColor='000000') def set_cell_style(ws, r, c, color): ws.cell(row=r, column=c).fill = PatternFill('solid', fgColor=color) ws.cell(row=r, column=c).font = Font(name="微軟雅黑", size=14, bold=True) ws.cell(row=r, column=c).alignment = Alignment(horizontal='right', vertical='center') side = Side(, color="004B3C") ws.cell(row=r, column=c).border = Border(top=side, bottom=side, left=side, right=side)
定義一個將表格顏色填充成白色的函數(shù),對表格初始化處理,將背景設(shè)置成純白,日歷看起來更美觀。
定義一個用于處理單元格格式的函數(shù),后面直接調(diào)用函數(shù)給單元格設(shè)置格式,方便重復(fù)使用。
import calendar # 將表格填充成白色 init_sheet(ws) # 設(shè)置年月單元格的邊框 side = Side(, color="004B3C") for col in range(7): ws.cell(row=1, column=col+1).border = Border(top=side, bottom=side, left=side, right=side) # 合并年月單元格 ws.merge_cells(start_row=1, start_column=1, end_row=1, end_column=7) # 寫入內(nèi)容和設(shè)置格式 ws.cell(row=1, column=1).value = '2022年8月' set_cell_style(ws, r=1, c=1, color='418CFA') # 寫入星期一至星期日,并設(shè)置格式 title_data = ['星期一', '星期二', '星期三', '星期四', '星期五', '星期六', '星期日'] for col in range(7): ws.cell(row=2, column=col+1).value = title_data[col] set_cell_style(ws, r=2, c=col+1, color='418CFA') # 獲取一個月的天數(shù)和第一天是星期幾 monthday = calendar.monthrange(2022, 8) # 設(shè)置日歷的日期 col, row = monthday[0], 3 for i in range(len(my_nucleic['date'])): if col < 7: ws.cell(row=row, column=col + 1).value = i+1 col += 1 else: col = 0 row += 1 ws.cell(row=row, column=col + 1).value = i+1 col += 1 # 設(shè)置單元格格式 set_cell_style(ws, r=row, c=col, color='000000') # 根據(jù)核酸結(jié)果填充顏色 if my_nucleic['nucleic'][i] == 1: ws.cell(row=row, column=col).fill = PatternFill('solid', fgColor='009B3C') # 設(shè)置行高 for i in range(1, row+1): ws.row_dimensions[i].height = 30 # 保存表格 wb.save(filename='show_august_nucleic.xlsx') wb.close()
日歷效果:
可以看到,8月份我只有4天沒有做核酸,大部分時間都是保持24小時。
代碼實現(xiàn)介紹:
先合并首行的前7列單元格,寫入年月,然后在第二行從左到右寫入星期一到星期日,并設(shè)置格式。
使用Python的日歷庫calendar返回當(dāng)前月第一天是星期幾,然后確定日歷的1號的起始位置。
從1號開始,依次在excel中寫入日期,當(dāng)列到達(dá)星期日時,換行并回到星期一的列。
根據(jù)當(dāng)天是否做了核酸,給單元格填充背景顏色。本文中如果當(dāng)天做了核酸,則日期的背景設(shè)置為綠色(24小時核酸碼的顏色),如果未做核酸,則日期的背景設(shè)置為白色。
最后將結(jié)果保存到excel文件中,打開excel文件即可看到制作的日歷。
制作了一個月的日歷后,繼續(xù)擴展做一年的日歷,先看一下效果:
實現(xiàn)方式介紹:
數(shù)據(jù)補充,由于只能查到一個月的核酸記錄,所以本文除2022年8月外,其他月份的數(shù)據(jù)用隨機數(shù)生成。
對制作一個月日歷的代碼進(jìn)行封裝,傳入年和月,就可以生成任意一個月的日歷。
在excel文件中,自己設(shè)計一排展示幾個月,本文一排展示3個月。并計算每個月日歷的起始單元格位置。
最后傳入年份,依次將一年12個月的日歷制作出來,展示在一個頁面上。只要有數(shù)據(jù),可以對任意一年的日歷進(jìn)行可視化。(代碼較長,可在文末獲取完整代碼)
按年的另一種展示方式:
from pyecharts import options as opts from pyecharts.charts import Calendar import pandas as pd nucleic_df = pd.DataFrame() for i in range(12): month_nucleic = made_data(2022, i+1) month_df = pd.DataFrame(month_nucleic) nucleic_df = pd.concat([nucleic_df, month_df]) data = [[row_data['date'], row_data['nucleic']] for row_index, row_data in nucleic_df.iterrows()] cal = Calendar(init_opts=opts.InitOpts(width='900px', height='500px')) cal.add( '', data, calendar_opts=opts.CalendarOpts(range_="2022", daylabel_opts=opts.CalendarDayLabelOpts(first_day=1, name_map='cn')) ).set_series_opts( label_opts=opts.LabelOpts(font_size=12) ).set_global_opts( title_opts=opts.TitleOpts(title='核酸檢測日歷', pos_left='450', pos_top='0', title_textstyle_opts=opts.TextStyleOpts(color='black', font_size=16)), visualmap_opts=opts.VisualMapOpts( max_=1, min_=0, orient="horizontal", is_piecewise=False, range_color=["white", "white", "green"], pos_top="250px", pos_left='50px' ), ).render('my_nucleic.html')
日歷效果:
pyecharts中的Calendar組件也可以實現(xiàn)日歷可視化,不過格式比較固定,展示得比較密集。
“如何用Python制作我的核酸檢測日歷”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!