chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

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

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

掃碼添加小助手

加入工程師交流群

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

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

1、項(xiàng)目背景

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

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

  • 爬取字段: 國(guó)家、國(guó)家ID、排名、金牌數(shù)、銀牌數(shù)、銅牌數(shù)、獎(jiǎng)牌總數(shù)、項(xiàng)目名、運(yùn)動(dòng)員、獲獎(jiǎng)?lì)愋?、獲獎(jiǎng)時(shí)間;
  • 爬取說明: 基于兩個(gè)接口的數(shù)據(jù)爬取【json格式的數(shù)據(jù)】,直接采用鍵值對(duì)的方式獲取相關(guān)數(shù)據(jù);
  • 使用工具: Pandas+requests

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

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

#這個(gè)鏈接主要展示:每個(gè)參賽隊(duì)員的參賽項(xiàng)目和獲得的獎(jiǎng)牌情況!
https://app-sc.miguvideo.com/vms-livedata/olympic-medal/total-table/15/110000004609

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

importrequests
importpandasaspd
frompprintimportpprint

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

pandas庫用于存儲(chǔ)和讀取獲取到的信息;

pprint庫是漂亮的打印,對(duì)于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),對(duì)于我們解析數(shù)據(jù)很有幫助。

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

直接利用鍵獲取對(duì)應(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','排名','金牌','銀牌','銅牌','獎(jiǎng)牌總數(shù)']
df1

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

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

是不是此時(shí)感覺結(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','獲獎(jiǎng)時(shí)間','項(xiàng)目名','運(yùn)動(dòng)員','金牌類型']
df2

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

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

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

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

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

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

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

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

最終效果如下:

表格df5表示運(yùn)動(dòng)項(xiàng)目獲獎(jiǎng)詳情,數(shù)據(jù)是這樣的:

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

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

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

上面得到的表df6,其實(shí)還不是最后的表,因?yàn)樯鲜霰碇薪鹋祁愋褪菙?shù)字1、2、3,但是我們需要的是金牌、銀牌、銅牌。因此,我們自己再定義一個(gè)df7。

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

效果如下:

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

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

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

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

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

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

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

withopen("國(guó)家名中英文對(duì)照表.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("國(guó)家名中英文對(duì)照表.xlsx",index=None)

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

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

結(jié)果如下:

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

4、可視化展示

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

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

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

責(zé)任編輯:haq

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

    關(guān)注

    1

    文章

    1264

    瀏覽量

    21866
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4827

    瀏覽量

    86759

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

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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