文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

在Python中搭建币价树形图

2024-12-03 09:04

关注

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

截至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键,就可以了!

 

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

总结

 

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

 

来源:区块链研究实验室 内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯