Python调用REST API接口的几种方式

原文链接

相信做过自动化运维的同学都用过REST API接口来完成某些动作。API是一套成熟系统所必需的接口,可以被其他系统或脚本来调用,这也是自动化运维的必修课。

本文主要介绍python中调用REST API的几种方式,下面是python中会用到的库。

  • urllib2

  • httplib2

  • pycurl

  • requests

urllib2

  • Sample1
import urllib2, urllib
github_url = 'https://api.github.com/user/repos'
password_manager = urllib2.HTTPPasswordMgrWithDefaultRealm()
password_manager.add_password(None, github_url, 'user', '***')
auth = urllib2.HTTPBasicAuthHandler(password_manager) # create an authentication handler
opener = urllib2.build_opener(auth) # create an opener with the authentication handler
urllib2.install_opener(opener) # install the opener... 
request = urllib2.Request(github_url, urllib.urlencode({'name':'Test repo', 'description': 'Some test repository'})) # Manual encoding required
handler = urllib2.urlopen(request)
print handler.read()
  • Sample2
import urllib2
url = 'http://ems.vip.ebay.com/removeSIforcloud.cgi?ip=' + ip
req = urllib2.Request(url)
req.add_header('IAF',abc.token_authiaas)
try:
    resp = urllib2.urlopen(req)
except urllib2.HTTPError, error:
    print "Cannot remove service instance!", error
    sys.exit(1)
response = resp.read()
print response
  • Sample3
import urllib2, urllib, base64
url = "https://reparo.stratus.ebay.com/reparo/bootstrap/registerasset/" + rackid + "/" + asset
data = urllib.urlencode({
                'reservedResource':'RR-Hadoop',
                'resourceCapability':'Production',
                'movetoironic':'False',
                'output':'json'
        })
print "Bootstrap Asset jobs starting .............."

base64string = base64.encodestring('%s:%s' % (user, passwd)).replace('\n', '')
request = urllib2.Request(url, data, headers={"Authorization" : "Basic %s" % base64string})
response = urllib2.urlopen(request).read()
response_json = json.loads(response)
response_status = response_json['status']
status_code = response_status['statusCode']
status = response_status['status']
message = response_status['message']           
print status_code , status, message

2. httplib2

import urllib, httplib2
github_url = '
h = httplib2.Http(".cache")
h.add_credentials("user", "******", "
data = urllib.urlencode({"name":"test"})
resp, content = h.request(github_url, "POST", data)
print content

3. pycurl

import pycurl, json
github_url = "
user_pwd = "user:*****"
data = json.dumps({"name": "test_repo", "description": "Some test repo"})
c = pycurl.Curl()
c.setopt(pycurl.URL, github_url)
c.setopt(pycurl.USERPWD, user_pwd)
c.setopt(pycurl.POST, 1)
c.setopt(pycurl.POSTFIELDS, data)
c.perform()

4. requests

import requests, json
github_url = "
data = json.dumps({'name':'test', 'description':'some test repo'}) 
r = requests.post(github_url, data, auth=('user', '*****'))
print r.json

以上几种方式都可以调用API来执行动作,但requests这种方式代码最简洁,最清晰,建议采用。

Python可以使用多种方式与数据库进行交互,包括使用原生数据库API、使用ORM框架和使用HTTP接口方式。 1. 使用原生数据库API Python提供了许多原生数据库API,可以直接使用这些API与数据库进行交互。例如,可以使用MySQLdb库与MySQL数据库进行交互,使用psycopg2库与PostgreSQL数据库进行交互,使用pyodbc库与Microsoft Access数据库进行交互等。 以下是使用MySQLdb库与MySQL数据库进行交互的示例代码: ```python import MySQLdb # 连接MySQL数据库 connection = MySQLdb.connect(host='localhost', user='your_username', passwd='your_password', db='your_database') # 获取游标 cursor = connection.cursor() # 执行SQL查询 cursor.execute('SELECT * FROM your_table_name') # 获取查询结果 results = cursor.fetchall() # 关闭游标和连接 cursor.close() connection.close() ``` 2. 使用ORM框架 ORM框架可以将数据库操作转换为Python对象的操作,使得操作更加简单和直观。常用的Python ORM框架包括SQLAlchemy、Django ORM、Peewee等。 以下是使用SQLAlchemy与MySQL数据库进行交互的示例代码: ```python from sqlalchemy import create_engine from sqlalchemy.orm import sessionmaker # 连接MySQL数据库 engine = create_engine('mysql+mysqldb://your_username:your_password@localhost/your_database') # 创建会话 Session = sessionmaker(bind=engine) session = Session() # 查询数据 results = session.query(YourModel).all() # 关闭会话 session.close() ``` 3. 使用HTTP接口 有些数据库提供了HTTP接口,可以通过HTTP请求与数据库进行交互。例如,可以使用MongoDB的REST API与MongoDB数据库进行交互。 以下是使用Python的requests库与MongoDB REST API进行交互的示例代码: ```python import requests # 查询数据 response = requests.get('http://localhost:28017/your_database/your_collection/_find') # 获取查询结果 results = response.json() ``` 以上是几种常见的Python与数据库交互的方式,可以根据实际情况选择合适的方式进行操作。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值