本篇文章给大家谈谈api接口获取数据,以及通过接口获取数据对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
今天给各位分享api接口获取数据的知识,其中也会对通过接口获取数据进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
如何使用 Yahoo Finance stock API 获取股票数据?
1、通过API获取实时数据
请求地址
http://finance.yahoo.com/d/quotes.csv?s=<股票名称f=<数据列选项
参数
s _ 表示股票名称,多个股票之间使用英文加号分隔,如”XOM+BBDb.TO+JNJ+MSFT”,罗列api接口获取数据了四个公司api接口获取数据的股票:XOM, BBDb.TO, JNJ, MSFT。
f _ 表示返回数据列,如”snd1l1yr”。更详细的参见雅虎股票 API f 参数对照表 。
2、通过API获取历史数据
请求地址
http://ichart.yahoo.com/table.csv?s=<stringa=<intb=<intc=<intd=<inte=<intf=<intg=dignore=.csv
参数
s _ 股票名称
a _ 起始时间,月
b _ 起始时间,日
c _ 起始时间,年
d _ 结束时间,月
e _ 结束时间,日
f _ 结束时间,年
g _ 时间周期。Example: g=w, 表示周期是’周’。d-’日’(day), w-’周’(week),m’月’(mouth),v-’dividends only’一定注意月份参数,其值比真实数据-1。如需要9月数据,则写为08。
3、通过API获取深沪股票数据
雅虎的API是国际性的,支持查询国内沪深股市的数据,但代码稍微变动一下,如浦发银行的代号是:600000.SS。规则是:上海市场末尾加.ss,深圳市场末尾加.sz。
股票数据的获取目前有如下两种方法可以获取:
1. http/javascript接口取数据。
2. web-service接口。
3.http/javascript接口取数据。
4.1Sina股票数据接口。
以大秦铁路(股票代码:601006)为例,如果要获取它的最新行情,只需访问新浪的股票数据。
接口:
简单获取新浪短网址API接口的方法(附PHP请求示例)
新浪短网址api是新浪官方对外公开的短网址生成接口,可以将冗长的链接地址缩短生成 t.cn 格式的短链接,下面分享一个获取新浪短网址API接口的方法以及接口请求方法。
1、在线使用
将API地址中 "http://www.baidu.com" 的部分换成自己的长网址,然后复制前往浏览器中粘贴打开就能生成了。
2、请求接口
如果嫌在线生成的流程很麻烦,可以将API接口对接到程序中请求生成,请求示例如下。
PHP请求示例:
Java请求示例:
Python请求示例:
1、调用API接口时,只需将 “http://www.baidu.com”换成需要缩短的长链接即可。
2、接口支持链接中带参数,但要注意的是当链接中出现 符号时,请用 %26 代替(或者使用url编码),否则参数可能会丢失。
3、更换链接时,必须要以http(s)://开头,否则可能会导致短网址生成失败或者生成的短网址无法跳转访问原网站。
4、上文提到的新浪短网址API接口,经测试都是比较稳定的,觉得好用记得收藏一下,以免丢失。
1、长链接转换后,为什么结尾的参数丢失了?
答:因为长链接中含有特殊字符,需要将url编码后再使用接口生成。
2、接口没有返回结果,是什么情况?
答:有些时候接口返回数据会有延迟,超时未返回即生成失败,也就不会返回结果;或者是因为原链接被封了。
3、生成的短链接有效期是多久?有没有访问次数限制?
答:生成的t.cn短链接是永久有效的,没有点击次数限制,可以放心使用。
从API接口获取的json数据怎么存到对象的List集合中
1. 简单的手动放置 键值对 到JSONObject,然后在put到JSONArray对象里
List<Article al = articleMng.find(f);
System.out.println(al.size());
HttpServletResponse hsr = ServletActionContext.getResponse();
if(null == al){
return ;
}
for(Article a : al){
System.out.println(a.getId()+a.getDescription()+a.getTitle());
}
JSONArray json = new JSONArray();
for(Article a : al){
JSONObject jo = new JSONObject();
jo.put("id", a.getId());
jo.put("title", a.getTitle());
jo.put("desc", a.getDescription());
json.put(jo);
}
try {
System.out.println(json.toString());
hsr.setCharacterEncoding("UTF-8");
hsr.getWriter().write(json.toString());
} catch (IOException e) {
e.printStackTrace();
}
复制代码
上述代码JSONArray是引入的org.json.JSONArray包
而用net.sf.json包下JSONArray的静态方法:fromObject(list) 这是网上大多是都是直接用此方法快捷转换JSON,但是对于Hibernate级联操作关联的对象,这个方法就会报错,如果将映射文件中的级联配置去掉就行了。
另外对于list的要求就是其中的元素是字符串或对象,否则JSON不知道你想要的是什么数据。
<many-to-one name="cmsent" column="comment_tid" class="com.fcms.cms.entity.CmsComment"
not-null="false" cascade="delete"
但是级联操作毕竟还是得存在,否则以后数据冗余、多余。
解决方法就是:JSONArray subMsgs = JSONArray.fromObject(object, config);
JsonConfig config = new JsonConfig();
config.setJsonPropertyFilter(new PropertyFilter() {
public boolean apply(Object arg0, String arg1, Object arg2) {
if (arg1.equals("article") ||arg1.equals("fans")) {
return true;
} else {
return false;
}
}
});
复制代码
说明:提供了一个过滤作用,如果遇到关联的对象时他会自动过滤掉,不去执行关联关联所关联的对象。这里我贴出我hibernate中的配置关系映射的代码帮助理解:
<!-- 配置话题和团体之间的关系 --
<many-to-one name="article" class="com.fcms.nubb.article" column="article_id"/
<!-- 配置主题帖与回复的帖子之间的关系 --
<set name="subMessages" table="sub_message" inverse="true" cascade="all" lazy="false" order-by="date asc"
<key column="theme_id" /
<one-to-many class="bbs.po.SubMessage" /
</set
总结:
1. JSONArray subMsgs = JSONArray.fromObject(subMessages, config);其中config是可选的,当出现上面的情况是可以配置config参数,如果没有上面的那种需求就可以直接使用fromObject(obj)方法,它转换出来的就是标准的json对象格式的数据,如下:
{["attr", "content", ...}, ...]}
2. JSONObject jTmsg = JSONObject.fromObject(themeMessage, config);这是专门用来解析标准的pojo,或者map对象的,pojo对象的格式就不用说了,map的形式是这样的{"str", "str"}。
package com.nubb.bean;
import java.io.Serializable;
public class Person implements Serializable{
private static final long serialVersionUID = 1L;
private String name;
private int age;
private String address;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
}
package com.nubb.test;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.StandardOpenOption;
import java.util.ArrayList;
import java.util.List;
import com.alibaba.fastjson.JSON;
import com.nubb.bean.Person;
public class JSONSerializer {
private static final String DEFAULT_CHARSET_NAME = "UTF-8";
public static <T String serialize(T object) {
return JSON.toJSONString(object);
}
public static <T T deserialize(String string, Class<T clz) {
return JSON.parseObject(string, clz);
}
public static <T T load(Path path, Class<T clz) throws IOException {
return deserialize(
new String(Files.readAllBytes(path), DEFAULT_CHARSET_NAME), clz);
}
public static <T void save(Path path, T object) throws IOException {
if (Files.notExists(path.getParent())) {
Files.createDirectories(path.getParent());
}
Files.write(path,
serialize(object).getBytes(DEFAULT_CHARSET_NAME),
StandardOpenOption.WRITE,
StandardOpenOption.CREATE,
StandardOpenOption.TRUNCATE_EXISTING);
}
public static void main(String[] args) {
Person person1 = new Person();
person1.setAddress("address");
person1.setAge(11);
person1.setName("amao");
Person person2 = new Person();
person2.setAddress("address");
person2.setAge(11);
person2.setName("amao");
List<Person lp = new ArrayList<Person();
lp.add(person1);
lp.add(person2);
System.out.println(serialize(lp));
}
}
输出:
[{"address":"address","age":11,"name":"amao"},{"address":"address","age":11,"name":"amao"}]
如何使用百度地图api获取数据
目前无任何使用限制。请申请key,然后使用该接口。
如何使用
第一步,申请key,点击这里获取密钥,申请key需要注册百度账号;
第二步,拼写发送http请求的url,注意需使用第一步申请的key;
第三步,接收http请求返回的数据(支持json和xml格式)。
服务地址
地址解析:根据地址获取坐标
http://api.map.baidu.com/geocoder?address=地址output=输出格式类型key=用户密钥city=城市名
逆地址解析:根据坐标获取地址
http://api.map.baidu.com/geocoder?location=纬度,经度output=输出格式类型key=用户密钥
备注:
1. city属于可选参数,通常情况可以不使用,若解析无结果,请尝试增加此字段。
2. 支持名胜古迹、标志性建筑物名称解析返回百度经纬度坐标,如address=“百度大厦”。
3. 支持使用“*路与*路交叉口”方式解析返回百度经纬度坐标,若地址库中存在该地址描述,返回百度经纬度坐标。
4. 若解析status字段为OK,若结果内容为空,原因分析及可尝试方法:
地址库里无此数据,本次结果为空。
加入city字段重新解析;
将过于详细或简单的地址更改至省市区县街道重新解析;
5. 特别提醒:逆地址解析location参数传入的参数格式是(纬度lat,经度lng)。

想问一下什么是API接口,具体是什么意思
API接口:
API(Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。
API函数包含在Windows系统目录下的动态连接库文件中。Windows API是一套用来控制Windows的各个部件的外观和行为的预先定义的Windows函数。
在linux中,用户编程接口API遵循了UNIX中最流行的应用编程界面标准---POSIX标准。POSIX标准是由IEEE和ISO/IEC共同开发的标准系统。
扩展资料:
API的程序功能:
远程过程调用(RPC):通过作用在共享数据缓存器上的过程(或任务)实现程序间的通信。
标准查询语言(SQL):是标准的访问数据的查询语言,通过通用数据库实现应用程序间的数据共享。
文件传输:文件传输通过发送格式化文件实现应用程序间数据共享。
信息交付:指松耦合或紧耦合应用程序间的小型格式化信息,通过程序间的直接通信实现数据共享。
当前应用于 API 的标准包括ANSI 标准SQL API。另外还有一些应用于其它类型的标准尚在制定之中。API 可以应用于所有计算机平台和操作系统。
参考资料来源:百度百科-api (应用程序编程接口)
从网络API接口上获取显示的字符数据,存储到本地Oracle或MySQL数据库
很多语言都可以做到,php/nodejs/java/python.....
如果你这些都不会,会shell 也可以做到,写入mysql没问题,oracle我不太知道行不行
我给你一个大概的shell例子,你应该就明白了
从json接口获得的数据是这些:
{
"data": [
{
"opentimestamp": 1520237469,
"opentime": "2018-03-05 16:11:09",
"opencode": "*,6,4,7,7",
"expect": "20180305061"
},
{
"opentimestamp": 1520236868,
"opentime": "2018-03-05 16:01:08",
"opencode": "*,4,8,2,9",
"expect": "20180305060"
},
{
"opentimestamp": 1520236269,
"opentime": "2018-03-05 15:51:09",
"opencode": "*,7,8,4,9",
"expect": "20180305059"
},
{
"opentimestamp": 1520235666,
"opentime": "2018-03-05 15:41:06",
"opencode": "*,3,9,9,9",
"expect": "20180305058"
},
{
"opentimestamp": 1520235069,
"opentime": "2018-03-05 15:31:09",
"opencode": "*,1,0,4,9",
"expect": "20180305057"
}
],
"info": "演示接口隐藏第1位数据,实时接口请访问www.opencai.net查询、购买或续费",
"code": "cqssc",
"rows": 5
}
shell 脚本如下,如果你想获得这个json的data value
#!/bin/sh
result=$(curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" "http://t.apiplus.net/newly.do?code=cqsscformat=json")
echo $result|jq -r ".data"
如果你想获得data 的第一个json数据
#!/bin/sh
result=$(curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" "http://t.apiplus.net/newly.do?code=cqsscformat=json")
echo $result|jq -r ".data[0]"
如果你想获得data的第一个json数据opentimestamp的value
#!/bin/sh
result=$(curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" "http://t.apiplus.net/newly.do?code=cqsscformat=json")
echo $result|jq -r ".data[0]"|jq -r .opentimestamp
如果你想写入到mysql可以参考下面的语句:
mysql -uroot -proot test -e "insert into ttest (key,value) values ('testkey','testvalue');"
关于api接口获取数据和通过接口获取数据的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
api接口获取数据的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于通过接口获取数据、api接口获取数据的信息别忘了在本站进行查找喔。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
暂时没有评论,来抢沙发吧~