如何直接从API中查询数据

日期:2015-11-16作者:Brad Irby翻译:崔婧雯 来源:TechTarget中国 英文

API   数据查询   

【TechTarget中国原创】

每天都有更多公司通过API在Web上发布他们的数据。访问并使用这些数据似乎成了懂得如何编程的“极客”特权。但是,借助Microsoft Excel和一些学习的决心,你也可以从API中直接得到数据,并且尽情地分析它们。

找到数据

从API中查询数据的第一步是找到想要分析的数据。

可以在Yahoo YQL console上查看。Yahoo提供了基于Web的工具来从大量数据源里查询数据,并且在浏览器里查看结果。让我们使用yahoo.finance.quotes表来获得股票价格。

输入YQL查询

在下面的输入框里,可以看到查询结果,得到的文本里有很多关于Microsoft股票价格的数据。在这些文本下面,有另一个输入框的标题写着“The REST Query”。这是运行以后能得到数据的完整查询。将其拷贝到剪贴板。

数据查询结果

如果将这个URL粘贴到新的浏览器窗口里(我将这个窗口称为XML展示窗口),会给你展示出和在Yahoon屏幕上一样的数据,但是格式更加便于阅读(如下)。我使用的是Chrome,不过所有浏览器都能显示类似结果。也要注意可以点击<符号旁边的钻石图标,来关闭这个节点,因为我对这段数据不感兴趣。

在XML展示窗口查看数据

缩小查询数据范围

下一步是找到想要使用的数据段,并且将其从不关心的信息里隔离出来。打开另一个浏览器窗口,进入XPath tester。这个网页能帮助试验XPath,这是一种用来查询XML的查询语言。

在Option 1输入框中,粘贴从Yahoo YQL console那里拷贝的URL,然后在XPath表达式的地方输入斜杠(/),并且点击Test XPath按钮(如下图所示)。在XPath结果栏,能够看到和之前屏幕上显示的同样文本。如果想要使用不同的XML数据源,用它代替Option 2栏的输入。

使用XPath查询SML

如果你不是XPath的专家,找到想要使用的数据的最简单方法是,通过尝试各种字符串看看能得到什么结果,来慢慢找到所需数据。如果检查XML显示窗口,你会注意到第一行都有“<query xmlns……”这样的字符串,以“<”符号元素开头,这就是我们想要找到的元素。将XPath表达式改成“/query”,并且点击Test XPath,就可以看到XPath结果变成了XML展示窗口显示的文本。

通过查看XML展示窗口,我们发现向Microsoft询价位于“quote”元素里面,从而又在“results”元素里,又在“query”元素里。将XPath表达式改变为“/query/results/quote/Ask”就能得到想要查找的数据。(注意XPath表达式是大小写敏感的。)

这个表达式能够显示所需数据

可以尽情尝试XPath表达式,来试验得到其他数据。

将数据导入到Excel

既然已经学会了所有知识,我们终于可以开始将数据导入到Excel来分析了。打开新的电子表格,在A1单元格写入“=WEBSERVICE("PutWebServiceURLHere")”,将Web服务端点地址写在两个双引号之间。Excel会停顿大概一秒钟,然后就会显示一长串XML文本——也就是你之前一直在处理的XML文本。

现在Excel里有了所有原始的XML。每次打开这个电子表格,数值会自动更新。

现在只需要裁剪所得到的数据

这是良好的开始,但是从API中得到的数据太多了。我们想要进行裁剪,只关注我们关心的数据。

在单元格A3里,写入 "=FILTERXML(A1,"/query/results/quote/Ask")"。这个命令的第一部分指代我们在单元格A1里查询到的所有XML数据,双引号里的第二部分是我们用XPath tester构造出来的XPath查询。可以看到只剩下了Microsoft股票的价格。

这是想要的数据的视图

如果想从相同的XML源处使用多个数值,只需要添加另一个FILTERXML命令。这里得到了Microsoft股票的成交量。

从相同XML源得到的Microsoft股票的成交量

现在你已经无需依赖开发人员来构建访问数据的工具,就可以在几分钟之内构建出自己的工具。

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

评论
查看更多评论

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

作者>更多

Brad Irby
Brad Irby

Brad Irby has been a developer and systems architect since 1990, designing and implementing systems using the Microsoft stack.

API>更多

  • API项目中 官方客户端不再是可有可无的

    在API项目中,有官方支持的客户端才能给API社区传达积极的信息。没有官方支持客户的API就像是没有方向盘的汽车。可能是辆好车,但是却哪儿也去不了。

  • Google收购Apigee,焦点在于企业本身还是API?

    Axway的Suraj Kumar认为Apigee收购案不一定是件好事。尽管Google也许会像Borg一样行动,这也许预示着Google的态度需要转变。

  • Google的新收购是否意味着API变得更酷了?

    Google对API管理解决方案提供商Apigee的收购,我们应该怎么评价呢?是为了打造一个改变游戏的联盟吗?或者只是技术巨头想尽快吞食市场份额的尝试?

  • 如何创建成功的RESTful API设计

    设计好的API是一项困难的任务,存在很多主观指标。哪怕是完全拥抱RESTfulAPI设计并对其问题域拥有完整视图的小型初创企业最终也会出现命名不一致、界面模糊以及无记录语义等问题。

相关推荐

  • API项目中 官方客户端不再是可有可无的

    在API项目中,有官方支持的客户端才能给API社区传达积极的信息。没有官方支持客户的API就像是没有方向盘的汽车。可能是辆好车,但是却哪儿也去不了。

  • Google收购Apigee,焦点在于企业本身还是API?

    Axway的Suraj Kumar认为Apigee收购案不一定是件好事。尽管Google也许会像Borg一样行动,这也许预示着Google的态度需要转变。

  • Google的新收购是否意味着API变得更酷了?

    Google对API管理解决方案提供商Apigee的收购,我们应该怎么评价呢?是为了打造一个改变游戏的联盟吗?或者只是技术巨头想尽快吞食市场份额的尝试?

  • API版本化与迁移五大策略

    API版本化和迁移是不得不解决的问题,特别是在应用程序接口和不断变化的业务优先级绑定越来越紧密的当下。但是,如果采取一些关键步骤,改动API就不会造成悲剧。

技术手册>更多

  • 云数据架构快速指南

    新的云数据架构快速指南提供在云数据架构中,您所需要的技巧、专家建议新闻、趋势和已经实施了云数据架构的企业现状是怎样的,下一步他们打算如何做。下面让我们看看详细内容。

  • 业务分析和监控指南

    在SearchSOA.com.cn之前的一些技术手册中,我们已经多次对BPM作出介绍。涉及了BPM的相当多的内容。在这本技术手册中,我们从着重关注业务活动分析和监控部分的内容。虽然BPM有益于企业的流程健康发展,但也并不是所有的企业都适合BPM。在确定了这些内容之后,我们还要考虑如何进行业务活动分析和监控。下面我们就来看看如何一步一步的实现BPM卓越中心。

  • SOA与REST混合使用指南

    大多数应用架构师都意识到,如果应用合适,开发实践反映了双方的目标和好处的话,在某些情况下,将表述性状态转移(REST)与SOA结合起来是有可能且有优势的。最大的问题是目标是否要开发一个自始至终的RESTful接口,同时满足大部分SOA目标,或者混合使用REST和SOA。

  • ESB选择备忘录

    也许你曾经设计一些架构,但都绕过了对于ESB的需求。因为你想知道从SOA的角度来看,ESB 究竟是好的还是坏的?曾经我们将EAI奉为圣杯,那么ESB和EAI究竟是什么关系呢?

TechTarget

最新资源
  • 安全
  • 存储
  • CIO
  • 数据库
  • 服务器
  • 云计算