99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何制作數(shù)據(jù)可視化大屏

Linux愛好者 ? 來源:數(shù)據(jù)分析與統(tǒng)計學(xué)之美 ? 作者:黃偉呢 ? 2021-10-12 16:31 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

經(jīng)常有小伙伴問,如何制作數(shù)據(jù)可視化大屏?

今天將手把手帶你爬取奧運會相關(guān)信息,并利用可視化大屏為你展示奧運詳情。讓一個沒關(guān)注過奧運會的朋友,也能夠秒懂奧運會。

1、項目背景

奧運會剛剛過去,你是否已經(jīng)看過2020東京奧運會呢?

2、奧運會相關(guān)信息爬取

  • 爬取字段: 國家、國家ID、排名、金牌數(shù)、銀牌數(shù)、銅牌數(shù)、獎牌總數(shù)、項目名、運動員、獲獎類型、獲獎時間;
  • 爬取說明: 基于兩個接口的數(shù)據(jù)爬取【json格式的數(shù)據(jù)】,直接采用鍵值對的方式獲取相關(guān)數(shù)據(jù);
  • 使用工具: Pandas+requests

本文是基于兩個接口的數(shù)據(jù)爬取,相對容易的多。

#這個鏈接主要展示:各國的金銀銅牌及其總數(shù)!
https://app-sc.miguvideo.com/vms-livedata/olympic-medal/total-table/15/110000004609

#這個鏈接主要展示:每個參賽隊員的參賽項目和獲得的獎牌情況!
https://app-sc.miguvideo.com/vms-livedata/olympic-medal/total-table/15/110000004609

① 導(dǎo)入相關(guān)庫

importrequests
importpandasaspd
frompprintimportpprint

requests庫用于發(fā)起網(wǎng)頁請求,獲取網(wǎng)頁中的源代碼;

pandas庫用于存儲和讀取獲取到的信息;

pprint庫是漂亮的打印,對于json格式的數(shù)據(jù),能夠很好的展示結(jié)構(gòu),方便我們解析;

② 爬蟲講解

url='https://app-sc.miguvideo.com/vms-livedata/olympic-medal/total-table/15/110000004609'
data=requests.get(url).json()
pprint(data)

三行代碼就可以獲取到網(wǎng)頁的源代碼,利用pprint庫,可以清晰的展示json結(jié)構(gòu),對于我們解析數(shù)據(jù)很有幫助。

我們要的數(shù)據(jù),都存在于body鍵下面的allMedalData鍵中,allMedalData鍵的值是一個列表,里面有很多字典組成的鍵值對信息,就是我們要爬取的數(shù)據(jù)。

直接利用鍵獲取對應(yīng)的值信息,代碼如下:

df1=pd.DataFrame()
forinfoindata1['body']['allMedalData']:
name=info['countryName']
name_id=info['countryId']
rank=info['rank']
gold=info['goldMedalNum']
silver=info['silverMedalNum']
bronze=info['bronzeMedalNum']
total=info['totalMedalNum']
#組織數(shù)據(jù)
orangized_data=[[name,name_id,rank,gold,silver,bronze,total]]
#然后追加df
df1=df1.append(orangized_data)
df1.columns=['名稱','ID','排名','金牌','銀牌','銅牌','獎牌總數(shù)']
df1

對于另外一個網(wǎng)頁,我們采取同樣的方式。

url='https://app-sc.miguvideo.com/vms-livedata/olympic-medal/detail-total/15/110000004609'
data2=requests.get(url).json()
pprint(data2)

是不是此時感覺結(jié)構(gòu)更清楚了?

df2=pd.DataFrame()
forinfoindata2['body']['medalTableDetail']:
english_name=info['countryName']
name_id=info['countryId']
award_time=info['awardTime']
item_name=info['bigItemName']
sports_name=info['sportsName']
medal_type=info['medalType']
#組織數(shù)據(jù)
orangized_data=[[english_name,name_id,award_time,item_name,sports_name,medal_type]]
#然后追加df
df2=df2.append(orangized_data)
df2.columns=['英文縮寫','ID','獲獎時間','項目名','運動員','金牌類型']
df2

3、數(shù)據(jù)預(yù)處理

對于爬取到的數(shù)據(jù),往往是有問題的,我們需要提前預(yù)處理一下,方便后續(xù)做可視化展示。

① 數(shù)據(jù)拼接

對我們共有三個表格,分別存儲著不同的信息。我們需要對其進(jìn)行合適的拼接,方便最后可視化。

表格df1表示各國獎牌數(shù),數(shù)據(jù)是這樣的:

表格df3表示國家名中英文對照表,數(shù)據(jù)是這樣的:

利用上述兩張表,我們可以左連接,將英文名稱添加到df1表上。

df4=pd.merge(df1,df3,on="名稱",how="left")
df4.head(10)

最終效果如下:

表格df5表示運動項目獲獎詳情,數(shù)據(jù)是這樣的:

此時,我們又可以將df4和df5做一個左連接,將這兩張表合成一張大表,就可以得到不同國家不同項目獲得的獎牌數(shù)。

df6=pd.merge(df4,df5,on="名稱",how="left")
df6.head(10)

② 關(guān)于金牌類型的說明

上面得到的表df6,其實還不是最后的表,因為上述表中金牌類型是數(shù)字1、2、3,但是我們需要的是金牌、銀牌、銅牌。因此,我們自己再定義一個df7。

x={"獲獎名次":["金牌","銀牌","銅牌"],"金牌類型":[1,2,3]}
df7=pd.DataFrame(x)
df7

效果如下:

af30f8e0-2ac9-11ec-82a8-dac502259ad0.png

因此,我們拿df6與自己構(gòu)造得到的df7再做一個左連接,就可以的到最后完整的表了。

df8=pd.merge(df6,df7,on="名稱",how="left")
df8.head(10)

③ 中英文名映射轉(zhuǎn)換

由于使用pyecharts繪制世界地圖時,名稱必須是英文的,所以我們需要將這里的中文名稱映射為英文名稱。于是我在網(wǎng)上找到了下面這個文件:

afec523e-2ac9-11ec-82a8-dac502259ad0.png

我們要做的就是將它與表格中的數(shù)據(jù),做個映射轉(zhuǎn)換。先把它轉(zhuǎn)換為一個Excel文件吧,方便我們以后直接使用。

withopen("國家名中英文對照表.txt","r",encoding="utf-8")asf:
x=f.read()

df3=pd.DataFrame()
foriinx.split("
"):
x=i.split(":")[0].strip()
y=i.split(":")[1].strip()
orangined_data=[[x,y]]
df3=df3.append(orangined_data)
df3.columns=["名稱","英文名稱"]
df3.to_excel("國家名中英文對照表.xlsx",index=None)

然后,在和上述的df2表格做一個左連接即可。

df4=pd.merge(df2,df3,on="名稱",how="left")
df4

結(jié)果如下:

adedc3a0-2ac9-11ec-82a8-dac502259ad0.png

4、可視化展示

關(guān)于可視化部分,使用的是pyecharts庫。這部分一共分以下8個主題:

  • ① 2020東京奧運會各國獎牌分布圖;
  • ② 2020東京奧運會獎牌榜詳情;
  • ③ 2020東京奧運會獎牌榜總數(shù)前十名;
  • ④ 2020東京奧運會金牌榜總數(shù)前十名;
  • ⑤ 2020東京奧運會中國各項目獲獎詳情;
  • ⑥ 中國選手每日獲得獎牌數(shù);
  • ⑦ 中國選手每日獲得金牌數(shù);
  • ⑧ 中國選手奪金詳細(xì)數(shù)據(jù);

說明: 這里就不做結(jié)果分析了,因為通過上圖,相信大家應(yīng)該能夠很清晰的了解到2020東京奧運會,哪怕你沒看過。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 可視化
    +關(guān)注

    關(guān)注

    1

    文章

    1262

    瀏覽量

    21847
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4827

    瀏覽量

    86695

原文標(biāo)題:用 Python 制作可視化大屏,特簡單!

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    工業(yè)設(shè)備數(shù)據(jù)集中監(jiān)控可視化管理平臺是什么

    工業(yè)設(shè)備數(shù)據(jù)集中監(jiān)控可視化管理平臺是一種用于整合、監(jiān)控和可視化工業(yè)設(shè)備數(shù)據(jù)的綜合性系統(tǒng),旨在幫助企業(yè)實現(xiàn)設(shè)備數(shù)據(jù)的集中管理、實時監(jiān)控和
    的頭像 發(fā)表于 05-06 11:10 ?225次閱讀

    可視化組態(tài)物聯(lián)網(wǎng)平臺是什么

    可視化組態(tài)物聯(lián)網(wǎng)平臺是物聯(lián)網(wǎng)技術(shù)與組態(tài)技術(shù)相結(jié)合的產(chǎn)物,是通過提供豐富的圖形組件和可視化元素,讓用戶能夠以直觀、便捷的方式對物聯(lián)網(wǎng)數(shù)據(jù)進(jìn)行監(jiān)控、分析和管理的平臺。以下是其具體介紹:
    的頭像 發(fā)表于 04-21 10:40 ?287次閱讀

    VirtualLab Fusion中的可視化設(shè)置

    通過以下控件進(jìn)行重置、加載和保存: 主窗口設(shè)置 字體配置 數(shù)字顯示 文檔窗口設(shè)置 1D數(shù)據(jù)數(shù)組可視化設(shè)置 顏色表 諧波場視圖
    發(fā)表于 02-25 08:51

    七款經(jīng)久不衰的數(shù)據(jù)可視化工具!

    鉆、上卷、切片、聯(lián)動等交互式分析方式,幫助用戶深入探索數(shù)據(jù)背后的規(guī)律。此外,F(xiàn)ineBI 支持豐富的圖表類型和自定義樣式,用戶可以根據(jù)需求自由組合,制作出精美的儀表盤和報表,增強了數(shù)據(jù)可視化
    發(fā)表于 01-19 15:24

    什么是大數(shù)據(jù)可視化?特點有哪些?

    數(shù)據(jù)可視化是指通過大屏幕展示大量數(shù)據(jù)和信息,以直觀、可視化的方式幫助用戶理解和分析數(shù)據(jù)。這種
    的頭像 發(fā)表于 12-16 16:59 ?676次閱讀

    可視化在水務(wù)領(lǐng)域都有哪些應(yīng)用場景?帶你一次看透!

    隨著科技的發(fā)展,大數(shù)據(jù)可視化技術(shù)逐漸成為水務(wù)領(lǐng)域的有力助手。博達(dá)智聯(lián)可視化設(shè)計平臺以其高度自定義、功能強大、多種圖表的特點,為水務(wù)行業(yè)提供了全新的解決方案。本文將詳細(xì)探討該平臺在
    的頭像 發(fā)表于 12-13 17:09 ?768次閱讀
    <b class='flag-5'>可視化</b>大<b class='flag-5'>屏</b>在水務(wù)領(lǐng)域都有哪些應(yīng)用場景?帶你一次看透!

    如何找到適合的大數(shù)據(jù)可視化系統(tǒng)

    選擇合適的大數(shù)據(jù)可視化系統(tǒng)是企業(yè)或組織在數(shù)字轉(zhuǎn)型過程中至關(guān)重要的一步。一個優(yōu)秀的大數(shù)據(jù)
    的頭像 發(fā)表于 12-13 15:47 ?481次閱讀

    可視化數(shù)據(jù)存在的重要性

    在當(dāng)今信息化時代,數(shù)據(jù)已經(jīng)成為企業(yè)決策制定和業(yè)務(wù)管理的關(guān)鍵驅(qū)動力。隨著數(shù)據(jù)量的急劇增長和各行各業(yè)對數(shù)據(jù)分析需求的提升, 可視化數(shù)據(jù)
    的頭像 發(fā)表于 12-05 16:27 ?692次閱讀

    智慧能源可視化監(jiān)管平臺——助力可視化能源數(shù)據(jù)管理

    博達(dá)可視化設(shè)計平臺在智慧能源領(lǐng)域的價值體現(xiàn)在實時監(jiān)控、數(shù)據(jù)可視化、決策支持和效率提升等方面。借助該平臺,企業(yè)可以輕松搭建智慧能源類可視化
    的頭像 發(fā)表于 11-29 10:00 ?943次閱讀
    智慧能源<b class='flag-5'>可視化</b>監(jiān)管平臺——助力<b class='flag-5'>可視化</b>能源<b class='flag-5'>數(shù)據(jù)</b>管理

    智慧樓宇可視化的優(yōu)點

    智慧樓宇可視化是指通過數(shù)據(jù)可視化技術(shù)來展示和分析樓宇的各種數(shù)據(jù),為樓宇管理者和用戶提供直觀、清晰的信息展示和決策支持。以下是智慧樓宇可視化
    的頭像 發(fā)表于 11-19 14:25 ?477次閱讀

    工業(yè)數(shù)據(jù)可視化管理平臺是什么

    數(shù)據(jù)可視化管理平臺應(yīng)運而生,它以其獨特的功能和優(yōu)勢,正在成為工業(yè)數(shù)字轉(zhuǎn)型的重要工具。 工業(yè)數(shù)據(jù)可視化管理平臺的定義 工業(yè)
    的頭像 發(fā)表于 08-28 14:21 ?634次閱讀

    可視化數(shù)據(jù)制作流程

    制作可視化數(shù)據(jù)是一項涵蓋數(shù)據(jù)分析、設(shè)計和技術(shù)實現(xiàn)的復(fù)雜任務(wù)。從數(shù)據(jù)處理到展示呈現(xiàn),每個步驟都
    的頭像 發(fā)表于 07-24 13:57 ?1161次閱讀