塔说 | 如何用Python分析数字加密货币

帮助

这篇文章的目的是简单介绍“如何用Python来分析数字加密货币”。我们将用简单的Python代码来检索、分析和可视化不同的数字货币数据。在这个过程中,我们将揭示一个有趣的趋势:这些不稳定的市场是如何运作的,它们又是如何发展的。

比特币市场到底是如何运作的?数字加密货币(cryptocurrency)跌宕起伏的原因是什么?不同的山寨币(altcoins)市场之间是紧密联系还是各自为营?我们该如何预测接下来将发生什么?

这不是一篇解释数字加密货币是什么的科普贴(如果你需要,我推荐这篇很棒的概述),这也不是一篇讲哪个货币会升值、哪个会贬值的观点性文章。相反,在这篇教程中,我们所关心的只是获取原始数据,并揭示隐藏在数字中的故事。

步骤1 - 配置你的数据实验室

这篇教材适合在不同技能水平上的爱好者、工程师和数据科学家们。要求的技能只是对Python有基础的了解,以及知道如何用命令建立一个项目。

包含运行结果的notebook完整版本可以在这里下载。

步骤1.1 - 安装 Anaconda

安装这个项目所需的所有相关环境,最简单的办法就是用Anaconda。它是一个打包的Python数据科学生态系统和依赖管理器。

推荐使用下面的官方安装指南来安装Anaconda https://www.continuum.io/downloads

如果你是一个高阶用户,而你不需要使用Anaconda,那也完全没有问题。我会假设你在安装必须的依赖环境时不需要帮助,你可以直接跳到第二部分。

步骤1.2 - 建立一个Anaconda项目环境

当Anaconda安装完成后,我们需要创建一个新的环境来管理我们的依赖包。运行 conda create --name cryptocurrency-analysis python=3 来为我们的项目创建一个新的Anaconda环境。接下来,运行source activate cryptocurrency-analysis ( Linux/macOS 系统) 或者 activate cryptocurrency-analysis (windows 系统) 来激活这个环境。

最后,运行 conda install numpy pandas nb_conda jupyter plotly quandl 来为这个环境安装所需的依赖包。完成这些需要几分钟的时间。

为什么要用环境?如果你打算在你的电脑上运行很多Python项目,那么分开不同项目的依赖包(软件库和包)来避免冲突是很有帮助的。

Ananconda会为每一个项目的依赖包创建一个特殊的环境目录,使得所有包都能妥善地被管理和区分。

步骤1.3 - 启动一个交互的Jupyter Notebook

当环境和依赖包都安装好之后,运行 jupyter notebook 来启动 iPython 内核,然后用你的浏览器访问http://localhost:8888/ 。创建一个新的Python notebook,确保它使用的内核是Python [conda env:cryptocurrency-analysis]。

步骤1.4 – 导入依赖包

当你打开了一个空的Jupyter notebook,我们要做的第一件事就是导入所需的依赖包。

我们还要导入Plotly来启用离线模式。

步骤2 - 获得比特币的价格数据

一切就绪,我们可以开始获取要分析的数据了。首先,我们要用Quandl的免费比特币接口来获得比特币的价格数据。

步骤2.1 - 编写Quandl帮助函数

为了方便数据获取,我们要编写一个函数来下载和同步来自Quandl(https://www.quandl.com/ 号称金融数据界的维基百科)的数据。

我们用pickle来序列化,把下载的数据存成文件,这样代码就不会在每次运行的时候重新下载同样的数据。这个函数将返回Pandas数据框(Dataframe)格式的数据。如果你对数据框不太熟悉,你可以把它想成是强大的电子表格。

步骤2.2 – 抓取Kraken交易所定价数据

我们首先来获取Kraken比特币交易所的历史比特币汇率。

我们可以用head()方法来查看数据框的前五行。

接下来,我们要做一个简单的图表,以此来快速地通过可视化的方法验证数据基本正确。

这里,我们用Plotly 来完成可视化部分。相对于使用一些更成熟的Python数据可视化库,例如Matplotlib ,用Plotly是一个不那么传统的选择,但我认为Plotly是一个不错的选择,因为它可以调用D3.js的充分交互式图表。这些图表有非常漂亮的默认设置,易于探索,而且非常方便嵌入到网页中。

我们可以将生成的图表与公开可用的比特币价格图表(如Coinbase上的图表)进行比较,作为一个快速的完整性检查,验证下载的数据是否合理。

步骤2.3 从更多的比特币交易所抓取价格数据

你可能已经注意到,上面的数据集中存在数据缺失现象--特别是在2014年末和2016年初。在Kraken交易所的数据集中,这种数据缺失情况尤为明显。我们当然不希望这些数据会影响到我们对价格的全面分析。

比特币交易所的特点是,供需关系决定比特币的价格。因而,没有哪个交易的价格所能够成为市场的“主流价格”。为了解决这个问题,以及刚刚提到的数据缺失问题(可能是由于技术性断电和数据的差错),我们将从三家主要的比特币交易所抓取数据,进而计算出平均的比特币价格指数。

首先,我们把各个交易所的数据下载到到由字典类型的数据框中。

步骤2.4 将所有价格数据整合到单一数据框之中

接下来,我们将要定义一个简单的函数,把各个数据框中共有的列合并为一个新的组合数据框。

现在,基于各个数据集的“加权价格”列,把所有的数据框整合到一起。

最后,可以使用“tail()”方法,查看合并后数据的最后五行,以确保数据整合成功。

看起来,这些数据符合我们的预期:数据范围大致相同,只是基于各个交易所的供求关系而略有不同。

步骤2.5 价格数据的可视化

从逻辑上来说,下一步就是通过可视化,将这些数据进行比对。为此,我们需要先定义一个辅助函数,通过提供单行命令使用数据制作图表。

为简便起见,我不会过多探讨这个辅助函数的工作原理。如果想了解更多,请查看Pandas 和 Plotly的说明文件。

现在,我们就可以轻松制作比特币价格数据的图形了!

步骤2.6 清理并加总价格数据

从以上图形中可以看到,尽管这四个系列数据遵循大致相同的路径,但其中还是有一些不规则的变化,我们将设法清除这些异常变化。

在2012-2017年的时间段中,我们知道比特币的价格从来没有等于零的时候,所以我们先去除数据框中所有的零值。

在重新构建数据框之后,我们可以看到更加清晰的图形,没有缺失数据的情况了。

我们现在可以计算一个新的列:所有交易所的比特币日平均价格。

新的一列就是比特币的价格指数!我们再把它画出来,以核对该数据看起来是否有问题。

太好了,看起来确实没有问题。稍后,我们将继续使用这个加总的价格序列数据,以便能够确定其他数字货币与美元之间的兑换汇率。

步骤3 获取山寨币(Altcoins)价格

现在,我们已经有了比特币价格的时间序列数据了。接下来我们来看看非比特币的数字加密货币的一些数据,一般是指山寨币(Altcoins)。

步骤3.1 定义Poloniex交易所的API辅助函数

我们将使用Poloniex API来获取数字加密货币交易的数据信息。我们定义了两个辅助函数来获取山寨币的相关数据,这两个函数主要是通过这个API下载和缓存JSON数据。

首先,我们定义函数get_json_data,它将从给定的URL中下载和缓存JSON数据。

然后,我们定义一个新的函数,该函数将产生Poloniex API的HTTP请求,并调用刚刚定义的get_json_data函数,以保存调用的数据结果。

上述函数将抽取加密货币配对字符代码(比如“BTC_ETH”),并返回包含两种货币历史兑换汇率的数据框。

步骤3.2 从Poloniex下载交易数据

绝大多数山寨币都无法使用美元直接购买,个人要想获取这些电子货币,通常都得先买比特币,再根据加密货币兑换汇率,兑换成山寨币。因而,我们就得下载每一种加密货币兑换比特币的兑换汇率,然后再使用现有比特币价格数据转换成美元。

我们会下载9种排名靠前的加密货币交易数据:Ethereum,Litecoin,Ripple,Ethereum Classic,Stellar,Dash,Siacoin,Monero,和NEM。

现在,我们有了包含9个数据框的字典,每种都包含山寨币与比特币之间的历史日平均价格数据。

我们可以通过Ethereum价格表格的最后几行,来判定数据是否可用。

altcoin_data['ETH'].tail()

步骤3.3 – 统一货币单位:美元

现在,我们可以将BTC-山寨币汇率数据与我们的比特币价格指数结合,来直接计算每一个山寨币的历史价格(单位:美元)。

此处,我们为每一个山寨币的数据框新增一列存储其相应的美元价格。

接着,我们可以重新使用之前定义的函数merge_dfs_on_column,来建立一个合并的数据框,整合每种电子货币的美元价格。

就是如此简单!

现在让我们同时把比特币价格作为最后一栏添加到合并后的数据框中。

现在我们有一个唯一的数据框,它包含了我们正在验证的十种电子货币的每日美元价格。

我们重新调用之前的函数df_scatter,以图表形式展现全部山寨币的相应价格。

看起来不错!这张图为我们展现了每一种货币兑换汇率在过去几年的变化情况的一个全貌。

在这里我们使用了对数规格的y轴,在同一绘图上比较所有货币。你也可以尝试其他不同的参数值(例如scale='linear'),可以从不同视角理解数据。

步骤3.4- 执行相关性分析

你可能注意到电子货币的汇率看上去似乎是相关的,尽管他们的货币价值相差很大,而且波动性很高。尤其是从2017年4月的迅猛上涨开始,甚至很多的小波动似乎都与整个市场的波动同步出现。

当然,有数据支撑的结论比依据图像而产生的直觉更有说服力。

我们可以利用Pandas corr()函数来验证上述的相关性假设。该检验手段为数据框的每一栏计算了其对应另一栏的皮尔森相关系数。

8/22/2017修订说明-这部分的修改是为了在计算相关系数时使用每日回报率而不是价格的绝对值。

基于一个非稳态时间序列(例如原始的价格数据)直接计算可能会导致相关性系数的偏差。针对此问题,我们的解决方案是使用pct_change()方法,将数据框中的每一个的价格绝对值转化为相应的日回报率。

首先,我们来计算2016年的相关系数。

上面这张图显示的都是相关系数。系数接近1或-1,分别意味着这一序列是强正相关的,或逆相关的,相关系数趋近于0则说明相应对象并不相关,他们的波动是相互独立的。

为了更可视化的展示结果,我们创建了一个新的可视化的帮助函数。

图示为2016年的电子货币相关系数

此处,深红色的数值代表强相关性(每一种货币显然是与其自身高度相关的),深蓝色的数值表示强逆相关性。所有介于中间的颜色-浅蓝/橙/灰/茶色-其数值代表不同程度的弱相关或不相关。

这张图表说明了什么呢?关键在于,它说明了不同的数字加密货币价格在2016年间的波动情况,几乎没有统计上的显著相关性。

现在,为了验证我们的假设-电子货币在近几个月的相关性增强,接下来,我们将使用从2017年开始的数据来重复同样的测试。

上图似乎显示了更强的相关性。但这些数据可以单独作为投资决策的依据吗?答案是否定的。

然而值得注意得是,在这张图上几乎所有的电子货币相互之间都变得相关性更强了。

图:2017年的电子货币相关性

这是不是相当有趣呢!?

为什么?

好问题!其实,我也不是很确定。。。

我的第一反应是,对冲基金最近开始公开在电子货币市场交易。这些基金持有远超于普通交易人的大量资本,当一支基金如果在多种加密货币间对冲自己的投入资本,然后根据独立变量(比如说,股票市场)对每一种货币使用相似的交易策略。如果从这个角度来看,出现这种越来越强的相关性趋势是合理的。

更深度的理解XRP和STR

例如,从上图中可以很明显看出XRP(Ripple的代币)是与其他电子货币相关性最低的。但这里有一个值得注意的例外是STR(Stellar的代币,官方名字是"Lumens"),与XRP有强相关关系(相关系数:0.62)。

有趣的是,Stellar和Ripple是非常相似的金融科技平台,他们都旨在减少银行间跨国转账时的繁琐步骤。

可想而知,考虑到区块链服务使用代币的相似性,一些大玩家以及对冲基金可能会对他们在Stellar和Ripple上的投资使用相似的交易战略。这可能就是为什么XRP相比其他电子货币,与STR有更强相关性的原因。

文章来源:大数据文摘

文章编辑:田芳

原文发布于微信公众号 - 灯塔大数据(DTbigdata)

原文发表时间:2017-12-14

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏CSDN技术头条

那些必读的数据库领域论文

之前林仕鼎曾整理过系统架构领域的学习资料,这几天Spark核心团队成员辛湜(Reynold Xin)公开了他整理的一份数据库学习资料列表,Hacker News...

338100
来自专栏程序人生

谈谈边界(Boundary)

上篇文章(Phoenix 1.3,迈向正确的道路)简单提了下「边界」,今早在火车上,顺着这个思路想了下去,写了篇 slide,中午分享给了团队。 我们做系统,做...

29560
来自专栏Golang语言社区

转--我们为什么选择Golang重构Worker系统

之前发了一篇帖子,讲了暴漫用golang重构了worker系统,有好多朋友问到语言选择的问题。 其实在用Golang重写我们的worker系统之前是做过很多调研...

44950
来自专栏币聪财经

币聪挖矿教程系列之:SimpleBank(SPLB)挖矿初学者指南

Simplebank是一款基于Dash的硬币,具有许多独特的功能和Masternodes。Simplebank希望成为一个数字加密货币银行类型平台,它将使商家和...

24420
来自专栏从零开始理解云计算

从零开始理解云计算 Vol.1:什么是云计算

这个系列其实是写给自己的云计算知识学习笔记——作为一个没有专业背景的小白,从零开始理解云计算的过程。王良明的《云计算通俗讲义》是一本入门的好书,本文根据书中的内...

1.6K20
来自专栏Netkiller

以太坊 Truffle 测试代币锁仓,转账,空投

中国广东省深圳市龙华新区民治街道溪山美地 518131 +86 13113668890 <netkiller@msn.com>

1.8K50
来自专栏程序员互动联盟

小菜学Chromium开发系列:OpenGL学习

风雨送春归,飞雪迎春到。已是悬崖百丈冰,犹有花枝俏。俏也不争春, 只把春来报。待到山花烂漫时,她在丛中笑。 这首《毛泽东诗词》·卜算子·咏...

30550
来自专栏量化投资与机器学习

【精华干货】Quant 需要哪些 Python 知识

谢谢大家的支持!现在该公众号开通了评论留言功能,你们对每篇推文的留言与问题,可以通过【写评论】给圈主留言,圈主会及时回复您的留言。 想在市场上赚钱,必须同时具备...

46150
来自专栏Netkiller

如何开发以太坊网页钱包·Express + web3.js 实例

中国广东省深圳市龙华新区民治街道溪山美地 518131 +86 13113668890 <netkiller@msn.com>

1.2K130
来自专栏嵌入式程序猿

怎么样用万用表检测IGBT

IGBT是变频器中非常重要的功率器件,这段时间给大家推送了多篇变频器拆解,设计的文章,而功率器件的好坏是检测中非常重要的一环,那么如何用万用表检测呢,我们以英飞...

60830

扫码关注云+社区

领取腾讯云代金券