我想在Python中执行一个curl命令。

通常,我只需要在终端输入命令,然后按回车键。但是,我不知道它在Python中是如何工作的。

命令如下所示:

curl -d @request.json --header "Content-Type: application/json" https://www.googleapis.com/qpxExpress/v1/trips/search?key=mykeyhere

有一个请求。Json文件发送以获得响应。

我找了很多遍,结果搞糊涂了。我试着写了一段代码,尽管我不能完全理解它,它没有工作。

import pycurl
import StringIO

response = StringIO.StringIO()
c = pycurl.Curl()
c.setopt(c.URL, 'https://www.googleapis.com/qpxExpress/v1/trips/search?key=mykeyhere')
c.setopt(c.WRITEFUNCTION, response.write)
c.setopt(c.HTTPHEADER, ['Content-Type: application/json','Accept-Charset: UTF-8'])
c.setopt(c.POSTFIELDS, '@request.json')
c.perform()
c.close()
print response.getvalue()
response.close()

错误消息是“解析错误”。如何正确地从服务器获得响应?


当前回答

我有这个确切的问题,因为我必须做一些事情来检索内容,但我所拥有的只是一个旧版本的Python,它对SSL的支持不足。如果你用的是老式MacBook,你就知道我在说什么了。在任何情况下,curl在shell中运行都很好(我怀疑它链接了现代SSL支持),因此有时您希望在不使用请求或urllib.request的情况下做到这一点。

你可以使用subprocess模块来执行curl并获取检索到的内容:

import subprocess

# 'response' contains a []byte with the retrieved content.
# use '-s' to keep curl quiet while it does its job, but
# it's useful to omit that while you're still writing code
# so you know if curl is working
response = subprocess.check_output(['curl', '-s', baseURL % page_num])

Python 3的子进程模块也包含带有许多有用选项的.run()。

其他回答

如果你的操作系统支持卷曲,你可以这样做:

import os

os.system("curl -d @request.json --header "Content-Type: application/json" https://www.googleapis.com/qpxExpress/v1/trips/search?key=mykeyhere")

我用这种方式…我想你也可以用这个!

顺便说一下…当你安装python时,“os”模块会自动安装。 su,你不需要安装包;)

使用curlconverter.com。它几乎可以将任何curl命令转换为Python, Node.js, PHP, R, Go等等。

例子:

curl -X POST -H 'Content-type: application/json' --data '{"text":"Hello, World!"}' https://hooks.slack.com/services/asdfasdfasdf

在Python中变成这样

import requests

json_data = {
    'text': 'Hello, World!',
}

response = requests.post('https://hooks.slack.com/services/asdfasdfasdf', json=json_data)

使用请求库..这段代码是:

curl -LH "Accept: text/x-bibliography; style=apa" https://doi.org/10.5438/0000-0C2G

等于这个:

import requests

headers = {
    'Accept': 'text/x-bibliography; style=apa',
}

r = requests.get('https://doi.org/10.5438/0000-0C2G', headers=headers)


print(r.text)

这是一种方法:

Import os
import requests 
Data = os.execute(curl URL)
R= Data.json()

我有这个确切的问题,因为我必须做一些事情来检索内容,但我所拥有的只是一个旧版本的Python,它对SSL的支持不足。如果你用的是老式MacBook,你就知道我在说什么了。在任何情况下,curl在shell中运行都很好(我怀疑它链接了现代SSL支持),因此有时您希望在不使用请求或urllib.request的情况下做到这一点。

你可以使用subprocess模块来执行curl并获取检索到的内容:

import subprocess

# 'response' contains a []byte with the retrieved content.
# use '-s' to keep curl quiet while it does its job, but
# it's useful to omit that while you're still writing code
# so you know if curl is working
response = subprocess.check_output(['curl', '-s', baseURL % page_num])

Python 3的子进程模块也包含带有许多有用选项的.run()。