微信号:bigdatalab

介绍:宽客俱乐部旗下美国大数据实验室,大数据研究应用.

Python 调用百度API

2016-06-06 07:27 大数据实验室

纸上得来终觉浅,绝知此事要躬行。

以前稍微看了一下百度的API,试了一下如何调用那些API,发现其实是很容易的。


步骤:

1.访问百度API Store;

2.找到想要调用的API,这里我尝试的是百度美女图片

Paste_Image.png

请求实例:

\# -\*- coding: utf-8 -\*-

import sys, urllib, urllib2, json

url = 'http://apis.baidu.com/txapi/mvtp/meinv?num=10'

req = urllib2.Request(url)

req.add_header("apikey", "您自己的apikey")

resp = urllib2.urlopen(req)

content = resp.read()

if(content):

    print(content)

3.按照说明,自己稍作修改即可。

我的代码:(比较乱,请谅解)

首先引入库,这里需要用到requests,json

import requests

  import json

然后写api地址,参数表

url = 'http://apis.baidu.com/txapi/mvtp/meinv'

headers = {'apikey':'*******(这里用你自己的apikey)'}

params = {'num':'10'}

发出请求,得到响应

r = requests.get(url,params = params,headers=headers)

r = r.json()

定义一个存图片的函数

def saveImage(imgUrl,imgName= 'default.jpg'):

    response = requests.get(imgUrl,stream = True)

    image = response.content

    dst = "f:\baidu_img\"

    path = dst+imgName

    print 'save the file:'+path+'\n'

    with open(path,'wb') as img:

       img.write(image)

    img.close()

开始获取图片地址,保存

def run():

    for line in r['newslist']:

        title = line['title'] 

       picUrl = line['picUrl']

       saveImage(picUrl,imgName=title+'.jpg')

run()


运行结果:

中国人民大学量化对冲高级研修班(三期),报名启动!

上课地点:北京

培训时间:2016年8月8日---8月12日

咨询电话/微信:13061694649


图片尺度过大,这里就不予显示了!


Paste_Image.png

对于其他的API的调用,原理都一样,按照要求发出请求,然后对响应文本进行解析,得到自己想要的数据。

下面再给一个api调用的实例代码,也是调用的图片(用有图片的例子来写,结果比较明显)

\# -*- coding:utf-8 -*-

import requests

url_1 = "http://www.tngou.net/tnfs/api/list"

\#url_2 = "http://www.tngou.net/tnfs/api/classify"

src_header = "http://tnfs.tngou.net/image"

headers = {'apikey':'*******(这里用你自己的apikey)'}

params_1 = {

    'page':3,

    'rows':20,

    'id':6      #需根据classify结果才能知道

}

r = requests.get(url_1)

r = r.json()

\#保存图片到本地路径

def saveImage(imgUrl,imgName= 'default.jpg'):

    response = requests.get(imgUrl,stream = True)

    image = response.content

    dst = "f:\baidu_img\"

    path = dst+imgName

    print 'save the file:'+path+'\n'

    with open(path,'wb') as img:

        img.write(image)

    img.close()

\#开始

def run():

    for line in r['tngou']:

        title = line['title']

        img = line['img']

        src_path = src_header+img

        saveImage(src_path,title+'.jpg')

run()


现在,是不是觉得很简单?当然,你也可以直接用requests,而不用调用API,对响应文本用正则表达式匹配,得到想要的数据。


作者:城楼听雪             来源:简书


版权声明:「大数据实验室」致力于优秀文章的交流与分享。部分文章推送时未能及时与原作者取得联系。若涉及版权问题,敬请原作者添加5424567微信联系删除。谢谢!





量化实战特训营第二期(北京站)火爆开启


软件使用,公式编写,海外模型讲解,短中长线趋势策略,套利策略,资金管理策略,高频交易策略,CTP接口,MATLAB复杂算法,期权量化 


2016年6月17-19日     北京    三天


咨询电话/微信:13061694649



 
大数据实验室 更多文章 用户画像数据建模方法 李光斗:警方是如何利用大数据抓到王全安的 降楼价,新加坡居然靠的是无人驾驶! 小数法则和经验主义 什么性格的人适合 Quant 这个职位?能否描述一下 Quant 一天的生活是怎样的?
猜您喜欢 C++11新特性Part11 猫友会帮优秀公司入驻武汉之“青藤云安全” “亲自鉴定”:出轨、交(yue)友(pao)网站套路解析 改变视角 有人向我反馈了一个bug