- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
将以下内容转换为 Python 请求调用的语法是什么?
curl -F file=@/your/data.csv http://host/ingest
我尝试过以下方法:
files = {'file': ('injestable_file', open(temp_file, 'rb'))}
requests.post(url,files=files)
但这不起作用,但相应的curl命令确实起作用。
最佳答案
您不能显示您的确切代码,因为您提供的curl 命令和您提供的代码有效。查看我的输出:
~ curl -F foo=bar -F file=@setup.py https://httpbin.org/post
{
"headers": {
"Accept": "*/*",
"Content-Length": "2370",
"Connection": "close",
"Host": "httpbin.org",
"User-Agent": "curl/7.29.0",
"Content-Type": "multipart/form-data; boundary=----------------------------959364026805"
},
"files": {
"file": "#!/usr/bin/env python\n\nimport sys\nimport os\nimport re\n\nkwargs = {}\nrequires = []\npackages = [\n \"github3\",\n \"github3.gists\",\n \"github3.repos\",\n \"github3.issues\",\n]\n\ntry:\n from setuptools import setup\n kwargs['test_suite'] = 'run_tests.collect_tests'\n kwargs['tests_require'] = ['mock', 'expecter', 'coverage==3.5.2']\n packages.append('tests')\nexcept ImportError:\n from distutils.core import setup # NOQA\n\nif sys.argv[-1] in (\"submit\", \"publish\"):\n os.system(\"python setup.py sdist upload\")\n sys.exit()\n\nrequires.extend([\"requests >= 1.2.3\", \"uritemplate.py >= 0.2.0\"])\n\n__version__ = ''\nwith open('github3/__init__.py', 'r') as fd:\n reg = re.compile(r'__version__ = [\\'\"]([^\\'\"]*)[\\'\"]')\n for line in fd:\n m = reg.match(line)\n if m:\n __version__ = m.group(1)\n break\n\nif not __version__:\n raise RuntimeError('Cannot find version information')\n\nsetup(\n name=\"github3.py\",\n version=__version__,\n description=(\"Python wrapper for the GitHub API\"\n \"(http://developer.github.com/v3)\"),\n long_description=\"\\n\\n\".join([open(\"README.rst\").read(),\n open(\"HISTORY.rst\").read()]),\n license=open('LICENSE').read(),\n author=\"Ian Cordasco\",\n author_email=\"graffatcolmingov@gmail.com\",\n url=\"https://github3py.readthedocs.org\",\n packages=packages,\n package_data={'': ['LICENSE', 'AUTHORS.rst']},\n include_package_data=True,\n install_requires=requires,\n classifiers=[\n 'Development Status :: 5 - Production/Stable',\n 'License :: OSI Approved',\n 'Intended Audience :: Developers',\n 'Programming Language :: Python',\n 'Programming Language :: Python :: 2',\n 'Programming Language :: Python :: 2.6',\n 'Programming Language :: Python :: 2.7',\n 'Programming Language :: Python :: 3',\n 'Programming Language :: Python :: 3.2',\n 'Programming Language :: Python :: 3.3',\n 'Programming Language :: Python :: Implementation :: CPython',\n ],\n **kwargs\n)\n"
},
"origin": "...",
"form": {
"foo": "bar"
},
"url": "http://httpbin.org/post",
"data": "",
"args": {},
"json": null
从交互式 python shell 中:
>>> import pprint as pp
>>> import requests
>>> pp.pprint(requests.post('https://httpbin.org/post', files={'file': ('filename', fd)}).json())
{u'args': {},
u'data': u'',
u'files': {u'file': u"#!/usr/bin/env python\n\nimport os\nimport sys\n\nimport requests\n\ntry:\n from setuptools import setup\nexcept ImportError:\n from distutils.core import setup\n\nif sys.argv[-1] == 'publish':\n os.system('python setup.py sdist upload')\n sys.exit()\n\npackages = [\n 'requests',\n 'requests.packages',\n 'requests.packages.charade',\n 'requests.packages.urllib3',\n 'requests.packages.urllib3.packages',\n 'requests.packages.urllib3.contrib',\n 'requests.packages.urllib3.packages.ssl_match_hostname'\n]\n\nrequires = []\n\nsetup(\n name='requests',\n version=requests.__version__,\n description='Python HTTP for Humans.',\n long_description=open('README.rst').read() + '\\n\\n' +\n open('HISTORY.rst').read(),\n author='Kenneth Reitz',\n author_email='me@kennethreitz.com',\n url='http://python-requests.org',\n packages=packages,\n package_data={'': ['LICENSE', 'NOTICE'], 'requests': ['*.pem']},\n package_dir={'requests': 'requests'},\n include_package_data=True,\n install_requires=requires,\n license=open('LICENSE').read(),\n zip_safe=False,\n classifiers=(\n 'Development Status :: 5 - Production/Stable',\n 'Intended Audience :: Developers',\n 'Natural Language :: English',\n 'License :: OSI Approved :: Apache Software License',\n 'Programming Language :: Python',\n 'Programming Language :: Python :: 2.6',\n 'Programming Language :: Python :: 2.7',\n 'Programming Language :: Python :: 3',\n 'Programming Language :: Python :: 3.3',\n\n ),\n)\n"},
u'form': {},
u'headers': {u'Accept': u'*/*',
u'Accept-Encoding': u'gzip, deflate, compress',
u'Connection': u'close',
u'Content-Length': u'1748',
u'Content-Type': u'multipart/form-data; boundary=d76a42fcaca84b3288ea4fa177bdad60',
u'Host': u'httpbin.org',
u'User-Agent': u'python-requests/1.2.3 CPython/2.7.3 Linux/3.2.29'},
u'json': None,
u'origin': u'...',
u'url': u'http://httpbin.org/post'}
除了窥视 unicode 文字之外,您的代码应该可以完美运行。
请编辑您的帖子并提供更多详细信息,包括您正在使用的请求版本以及有关您尝试发布的数据的更多详细信息。当您发布的内容完全正确时,我们无法为您提供帮助。
关于python - 使用 Python 请求复制 Curl 命令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18618658/
我以前从未做过任何 curl ,所以需要一些帮助。我试图从示例中解决这个问题,但无法理解它! 我有一个 curl 命令,我可以从 Windows 命令行成功运行该命令,该命令行在 Solr 中索引 p
curl -v有什么区别和 curl -I ? 我可以看到 -v是冗长的和 -I是标题。有什么具体的吗? 最佳答案 -I (大写字母 i)在 curl 中表示“没有正文”,对于 HTTP 表示发送 H
我正在使用curl php API访问FTP链接。在特定站点上,它给出错误代码9(拒绝访问)。但是,可以从IE和Firefox访问该链接。 然后,我运行curl命令行,它给出了相同的“访问拒绝”结果。
我已经使用curl有一段时间了,它可以正常工作,但是使用使用用户'domain\username'来验证curl的代理时,无法请求授权。授权方法是NTLM。此代码放入批处理文件中。 代码: curl
“curl”默认使用哪些证书? 例子: curl -I -L https://cruises.webjet.com.au 在 Ubuntu 15.04 上失败 curl: (60) SSL certi
我知道终端输出的一部分是请求的持续时间,剩余时间等。但是是否有一些文档指定了curl命令的终端输出的每一列到底是什么?手册页上的内容非常稀疏。 最佳答案 可能不容易找到,但已在the curl boo
我想通过 curl 在我自己的云服务器上的特定文件夹中上传文件。例如:http://www.myowncloudserver.com/remote.php/webdav/{MY_FOLDER}。此时我
我的网站上有一个密码保护的Web文件夹,我正在使用Curl在另一个域上获取该文件夹,我想要的是:当我尝试打开URL时,应该问我用户名和密码,而不是让它显示“需要授权”。 例: http://www.e
有没有一种方法可以通过简单的Curl获取Rabbitmq中队列的大小(剩余消息)? 类似于curl -xget http://host:1234/api/queue/test/stats 谢谢 最佳答
关闭。这个问题是opinion-based .它目前不接受答案。 2年前关闭。 锁定。这个问题及其答案是locked因为这个问题是题外话,但具有历史意义。它目前不接受新的答案或互动。 我最近开始在我的
我想访问需要用户名/密码的 URL。我想尝试用curl 访问它。现在我正在做类似的事情: curl http://api.somesite.com/test/blah?something=123 我收
我正在尝试使用 CURL 进行查询ElasticSearch 中的命令在windows平台。 例如:localhost:9200/playground/equipment/1?pretty 我收到一条
我正在尝试使用 Docker 构建和运行 Marklogic 实例。 Marklogic 提供了一些不错的 http api,所以,作为最终 CMD在 Dockerfile 中,我运行两个脚本,它们通
我正在尝试通过 cURL 检索网页的内容(比方说 http://www.foo.com/bar.php )。 当我在浏览器中加载网站时,加载页面时会出现动画,页面最终会显示出来。 但是使用 cURL,
我正在尝试使用带代理的命令行 CURL 获取响应状态代码。 这会返回整个页面,但我只想要状态代码。我怎么做?谢谢。 curl -sL -w -x IP:PORT "%{http_code}\n""ht
我有一段代码检查 http/s 端点的状态和加载时间。然后我会为每个顶级页面检查 1 级 href,以检查页面引用的所有内容是否也加载了 200。 (我查了50个顶级页面,每个顶级页面平均有8个链接)
curl --upload-file 和 curl --form file=@/path/file 有什么区别?这些 HTTP 请求有何不同? 最佳答案 --上传文件 (使用 HTTP 或 HTTPS
我正在尝试使用 system-curl 安装 cmake,使用 ./bootstrap --system-curl,如 here 所示.这样做,我得到了: -- Could NOT find
我需要使用 Curl 下载 Youtube 视频的特定部分。 (假设我想下载前 2MB)我在 Curl 中使用 -r 开关来实现这一点。它适用于非 YouTube 链接,但 Youtube 链接会忽略
我希望在使用 curl 命令从远程服务器下载文件后,将时间戳或日期添加到文件名中。我知道您可以使用 -o 来指定您要为文件命名的内容。我看到过这样的建议:-o "somefile $(date +\"
我是一名优秀的程序员,十分优秀!