【Python】繪製空氣質量日曆圖

来源:https://www.cnblogs.com/123456feng/archive/2022/04/08/16112309.html
-Advertisement-
Play Games

前言 在github中經常可以看到下麵的日曆圖,可以用來表示每一天在github上的活躍程度。 類似的方法也可以用到空氣質量的可視化方式中來,只要有每天的空氣質量指數就可以。 數據 我這裡使用的是2020年北京市各個監測站點的空氣質量觀測數據,原始數據包含PM2.5,PM10,AQI指數,這裡選擇A ...


前言

在github中經常可以看到下麵的日曆圖,可以用來表示每一天在github上的活躍程度。

在這裡插入圖片描述

類似的方法也可以用到空氣質量的可視化方式中來,只要有每天的空氣質量指數就可以。

在這裡插入圖片描述

數據

我這裡使用的是2020年北京市各個監測站點的空氣質量觀測數據,原始數據包含PM2.5,PM10,AQI指數,這裡選擇AQI作為示例。

這裡對原始數據做了簡單處理,具體過程不贅述,感興趣的話也可以看文末獲取方式。處理後的數據形式如下:

在這裡插入圖片描述

calmap

繪製日曆圖可以用calmap庫直接繪製,安裝直接用pip。
詳細可視化方法如下:

定義可視化方式

Python學習交流Q群:906715085####
def calendar_heatmap(df, title):
    # 定義顏色
    color_list = ['#009966', '#FFDE33', '#FF9A32', '#CC0033', '#660099']
    levels = [0, 50, 100, 150, 200, 300]

    cmap = colors.ListedColormap(color_list)  
    norm = colors.BoundaryNorm(levels, cmap_aqi.N)
    
    # 繪圖
    fig, ax = plt.subplots(figsize=(18, 9))

    calmap.yearplot(
        df,              
        vmin=0, 
        vmax=300,                  
        cmap=cmap, 
        norm=norm, 
        how=None, 
        year=2020,
    )

    cbar_ax  = fig.add_axes([0.94, 0.4, 0.015, 0.2])
    cb  = mpl.colorbar.ColorbarBase(
        cbar_ax, 
        cmap=cmap, 
        ticks=levels,              
        norm=norm, 
        orientation='vertical',               
        extend='neither', 
        extendrect=True,                         
        extendfrac=0.15
    )
    
    # 色標
    cb.set_ticks([0, 50, 100, 150, 200, 300])
    cb.ax.yaxis.set_tick_params(length=0.01)
    ax.set_ylabel('2020', fontdict=dict(fontsize=25, color='grey'))
    
    # 標題
    ax.set_title(f'AQI of {title}', fontweight = 'bold', fontsize = 25)
    plt.savefig(f'{title}_calendar_heatmap.png')

 

在這裡插入圖片描述

繪圖

cp = df.resample('1d').mean().round(2)['昌平']
calendar_heatmap(cp, 'Changping')

 

在這裡插入圖片描述

dx = df.resample('1d').mean().round(2)['大興']
calendar_heatmap(dx, 'DaXing')

 

在這裡插入圖片描述

最後也對兩個測站的空氣質量做了個統計

cp_bin = pd.cut(
    cp, 
    bins=[0, 50, 100, 150, 200, 300],
    right=False
).value_counts()

 

在這裡插入圖片描述

dx_bin = pd.cut(
dx,
bins=[0, 50, 100, 150, 200, 300],
right=False
).value_counts()

 

在這裡插入圖片描述

最後
這一篇給大家簡單的製作這麼一個日曆圖,代碼就放到上面了,喜歡的小伙伴記得點贊收藏,下一章見啦。

在這裡插入圖片描述


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一直以來,中式占卜都是基於算命先生手工實現,程式繁瑣(往往需要沐浴、計算天時、靜心等等流程)。準備工作複雜(通常需要銅錢等道具),計算方法複雜,需要純手工計算二進位並轉換為最終的卦象,為瞭解決這個問題,筆者基於python實現了一套科學算命工具,用於快速進行占卜。 本文的算命方式採用八卦 + 周易+ ...
  • RPC及Dubbo和ZooKeeper的安裝 RPC 通信有兩種方式:HTTP(無狀態協議,通信協議),RPC(遠程過程調用) 它兩的本質沒有區別,只是功能有點不一樣 官方解釋: RPC是指遠程過程調用,是一種進程間通信方式,他是一種技術的思想,而不是規範,它允許程式調用另一個地址空間的過程和函數, ...
  • 前言 和換臉演算法的簡單粗暴相比,人臉融合演算法就要彈性的多。顧名思義,人臉融合是對兩張人臉進行融合處理,生成的人臉同時具 備兩張人臉的外貌特征。人臉融合有什麼實際意義呢?一個簡單的應用就是用父母雙方的臉部圖片融合,得到未來孩子可能的長相。 本文通過百度AI開放平臺的人臉融合功能來做一個簡單的試驗。 前 ...
  • 我們在觀看視頻的時候,有時候會出現一些奇怪的馬賽克,影響我們的觀影體驗,那麼這些馬賽克是如何精確的加上去的呢? 本次我們就來用Python實現對視頻自動打碼! 準備工作 環境咱們還是使用 Python3.8 和 pycharm2021 即可 實現原理 將視頻分為音頻和畫面; 畫面中出現人臉和目標比對 ...
  • strings.Builder 源碼解析、 存在意義、 實現原理、 常用方法、 寫入方法、 擴容方法、 String() 方法、 禁止複製、 線程不安全、 io.Writer 介面、 代碼、 strings.Join 源... ...
  • 最近《孤勇者》這首歌特別火,我也覺得很好聽,不得不給陳奕迅點一個大大的贊。今天想用Python來做一個《孤勇者》的畫圖以及音樂可視化。 python里有個叫做 turtle 的庫,用它提供的方法可以很簡單的畫線和塗色: Python學習交流Q群:906715085#### import turtle ...
  • 作者:xbhog 鏈接:www.cnblogs.com/xbhog/p/15207278.html 異常處理: 背景: 最近在搭建屬於自己的個人博客(碼農小白的執念),自己搭建後端的時候首先考慮的是異常處理。個人也是一邊學習一邊做,難免有疏漏的地方,希望朋友們在不對的地方提醒下。 技術棧: spri ...
  • 最近這段時間,一些互聯網大廠把裁員稱為“畢業”的話題被熱議了很久。 上午,DD在網上瞎逛看到了一篇文章,似乎找了這一做法的祖先。原來這麼有“創意”的操作,很好多年前的漂亮過就已經有了,所以其實這也是個舶來品? 在這篇發表於2016年4月的文章中,據作者稱:他在軟體公司HubSpot工作了近兩年,當有 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...