在Python中搭建币价树形图

开发 后端
截至2021年3月,有8,000多种加密货币,因此一目了然地跟踪所有价格的发展可能是具有挑战性的。幸运的是,像coin360这样的网站以树形图的形式提供了加密货币价格发展的简洁可视化。

[[387495]]

本文转载自微信公众号「区块链研究实验室」,作者链三丰 。转载本文请联系区块链研究实验室公众号。  

截至2021年3月,有8,000多种加密货币,因此一目了然地跟踪所有价格的发展可能是具有挑战性的。幸运的是,像coin360这样的网站以树形图的形式提供了加密货币价格发展的简洁可视化。树状图通过使用可变大小的矩形以嵌套结构的形式显示比例价格数据,从而提供了所有加密货币的快速概览。

对此概念感兴趣,我决定尝试使用Python创建我自己的版本的树形图以跟踪加密价格的想法。此树形图教程不仅限于显示加密信息,还可以应用于几乎任何其他数据。

为了最大程度地提高Python代码的可移植性,本教程使用Google Colab创建,因此笔记本可以在任何Chrome浏览器上运行。

本教程的3个主要组成部分是:

如何使用CoinMarketCap API调用和检索最近24小时内的加密货币价格

使用库Squarify在Python中绘制静态树图

使用库Plotly在Python中绘制交互式树图

从CoinMarketCap检索加密数据

 

免责声明:CoinMarketCap数据的免费版本仅供个人使用,出于商业目的,请参阅CMC的定价计划。

首先,如果您还没有的话,您需要在此处注册一个开发者帐户。登录后,导航至仪表板并复制唯一的API密钥。

 

CoinMarketCap截图

通过使用下面显示的代码片段,您应该能够从CoinMarketCap调用前10个加密数据。可以调整参数以包括更多或更少的数据以及所使用的货币。切记在第15行中替换您的API密钥。此代码段在发布时是最新的,有关将来的任何更新,请参阅官方文档。

  1. #This example uses Python 2.7 and the python-request library. 
  2.  
  3. from requests import Request, Session 
  4. from requests.exceptions import ConnectionError, Timeout, TooManyRedirects 
  5. import json 
  6.  
  7. url = 'https://pro-api.coinmarketcap.com/v1/cryptocurrency/listings/latest' 
  8. parameters = { 
  9.   'start':'1'
  10.   'limit':'10'
  11.   'convert':'USD' 
  12. headers = { 
  13.   'Accepts''application/json'
  14.   'X-CMC_PRO_API_KEY''#REPLACE YOUR API KEY HERE#'
  15.  
  16. session = Session() 
  17. session.headers.update(headers) 
  18.  
  19. try: 
  20.     response = session.get(url, params=parameters) 
  21.     data = json.loads(response.text) 
  22.     print(data) 
  23. except (ConnectionError, Timeout, TooManyRedirects) as e: 
  24.     print(e) 

API返回的数据为JSON格式,因此需要以pythonic数据框格式进行规范化(请参见第4行)。还对数据进行过滤,以仅保留与树图相关的几列,即加密货币的名称,排名,价格及其关联的市值(请参阅第5行)。

  1. import pandas as pd 
  2.  
  3. #normalize the data into dataframe format 
  4. df = pd.json_normalize(data["data"]) 
  5. cols_to_keep = ['name','symbol','cmc_rank','quote.USD.price','quote.USD.percent_change_24h','quote.USD.market_cap',] 
  6. df_final = df[cols_to_keep] 
  7. #rename columns 
  8. df_final.columns = ['name','symbol','cmc_rank','USD_price','USD_percent_change_24h','USD_market_cap',] 
  9. #uncomment below to print the table 
  10. #df_final 

创建一个静态树图

 

使用Squarify创建的树图

Squarify是树图布局算法的库实现。它通过计算数据大小并返回矩形的一系列坐标来工作,然后使用绘制这些坐标MatPlotLib。可以使用颜色编码的参数来可视化变化的规模,在此示例中,其是过去24小时内价格变化的百分比。但是,不利的一面是,目前尚无直接实现可根据变化的矩形的大小来缩放标签的方法。Python代码如下。

  1. import matplotlib 
  2. import matplotlib.pyplot as plt 
  3. #!pip install squarify 
  4. import squarify  
  5.  
  6. #load data 
  7. sizes=df_final["USD_market_cap"
  8. label=df_final["name"
  9.  
  10. # color scale on the price development  
  11. min and max values 
  12. cmap = matplotlib.cm.RdYlGn #RedYellowGreen 
  13. mini=min(df_final["USD_percent_change_24h"]) 
  14. maxi=max(df_final["USD_percent_change_24h"]) 
  15. norm = matplotlib.colors.Normalize(vmin=mini, vmax=maxi) 
  16. colors = [cmap(norm(value)) for value in df_final["USD_percent_change_24h"]] 
  17.  
  18. # labels in treemap squares 
  19. labels = ["%s\n%d USD\n%0.2f%%" % (label) for label in zip(df_final.symbol, df_final["USD_price"], df_final["USD_percent_change_24h"])] 
  20.  
  21. # make plot 
  22. fig = plt.figure(figsize=(20, 10)) 
  23. ax = fig.add_subplot(111, aspect="auto"
  24. ax = squarify.plot(df_final["USD_market_cap"], color=colors, label=labels,  alpha=.8) 
  25. ax.set_title("Cryptomarket price change last 24 hours\n", fontsize=18) 
  26.  
  27. # plot title and color bar 
  28. img = plt.imshow([df_final["USD_percent_change_24h"]], cmap=cmap) 
  29. img.set_visible(True
  30. fig.colorbar(img, orientation="vertical", shrink=.96) 
  31. fig.text(.76, .9, "Percentage change", fontsize=14) 
  32.  
  33. # if you want to export the figure 
  34. #plt.savefig("cmc_treemaps.png"
  35. plt.show() 

说明:

第1至4行:导入并安装(如果需要)所需的库

第6-8行:加载树形图的数据

第10-16行:对价格变化百分比应用颜色编码的缩放比例

第18-19行:为要显示的文本创建字符串标签

第21–25行:绘制树形图

第27–31行:在侧面应用颜色条

第33–35行:显示树状图,并带有将其导出为png图像的选项

创建交互式树形图

 

扫码查看交互式树形图效果

绘制树图的一种更复杂的方法是将其激活!使用Plotly可以创建一个交互式树状图,当您在每个矩形块上悬停时,它会显示有关每个矩形块的详细信息。Plotly在后台为您完成了大部分工作,从而导致与Squarify相比,更少的代码行更加精简和优雅。

  1. #!pip install --upgrade plotly 
  2. import plotly.graph_objects as go 
  3. import plotly.express as px 
  4.  
  5. fig = px.treemap(df_final,  
  6.                  path=['name'],  
  7.                  values='USD_market_cap'
  8.                  color_continuous_scale='RdYlGn'
  9.                  color='USD_percent_change_24h',             
  10.                  ) 
  11. fig.update_layout(title_text='Cryptomarket price change last 24 hours', title_x=0.5) 
  12. fig.show() 

说明:

第1至3行:导入并安装所需的库

第5-10行:绘制树形图

第11行:在树形图上添加标题

第12行:显示树状图

如何在媒体/网站中嵌入交互式树图

想知道您上面看到的嵌入式树形图是如何完成的?您可以使用Plotly Studio轻松地做到这一点,而好处是您可以直接将Google Colab笔记本与Plotly Studio关联(您需要有一个帐户)。只需在下面添加此代码段,然后使用您的Plotly用户名和API密钥即可完成。

  1. #To push your GC plot to Plotly Studio automatically 
  2. #!pip install chart_studio 
  3. import chart_studio  
  4. import chart_studio.plotly as py 
  5.  
  6. username = '#REPLACE YOUR USERNAME HERE#' # your username 
  7. api_key = '#REPLACE YOUR API KEY HERE#' # your api key - go to profile > settings > regenerate key 
  8. chart_studio.tools.set_credentials_file(username=username, api_key=api_key) 
  9. py.plot(fig, filename = 'cmc_treemap', auto_open=True

将您的Plotly树图推入/同步到Plotly Studio后,只需将链接复制到Plotly Studio,然后将该链接粘贴到Medium中作为嵌入式链接,然后按Enter键,就可以了!

 

如何在网站上上插入嵌入式链接

总结

 

通过可视化不同矩形和颜色的层次结构数据,树形图是讲述故事的好方法。当您要按大小顺序快速可视化大量数据,以及可以选择对第二维使用不同色调和颜色强度的选项时,此功能非常有效。但是,树形图的一个缺点是进行精确的定量比较可能具有挑战性。

 

责任编辑:武晓燕 来源: 区块链研究实验室
相关推荐

2022-06-13 10:39:12

JavaScript

2009-07-28 13:48:28

ASP.NET树形图

2022-04-14 07:57:52

Python代码热力图

2021-02-16 00:23:02

比特币加密货币数字货币

2021-02-01 17:35:47

CommitsGit币价先行指标

2012-07-09 09:31:53

silverlight

2017-02-28 10:11:14

Mac OSXPython开发环境

2009-07-03 19:18:04

BTIM服务应用管理

2020-06-30 20:55:17

PygalPython编程语言

2022-06-17 14:51:16

比特币数字技术支付系统

2022-10-24 09:00:47

画图工具程序员XMind

2021-04-29 15:45:47

比特币加密货币货币

2012-02-28 10:33:27

Eclipse 3.7Android环境

2011-06-03 14:04:11

Android

2018-11-26 18:45:22

数据可视化绘图可视化

2009-03-05 10:10:52

饼图数据库JSP

2009-06-25 16:36:31

JBPM流程图

2011-03-10 14:40:48

LAMP搭建

2022-05-05 14:16:19

加密货币币安监管机构

2021-04-12 22:24:28

稳定币加密货币金融
点赞
收藏

51CTO技术栈公众号