Мои исследования показывают, что нет простого способа сделать это с помощью стандартной библиотеки Python. Я использую Python 3.
(Примечание: см. пакет под названием Requests (ссылка PyPI), чтобы легко это сделать)
В настоящее время я использую этот метод:
Код: Выделить всё
import mimetypes, http.client
boundary = 'wL36Yn8afVp8Ag7AmP8qZ0SA4n1v9T' # Randomly generated
for fileName in fileList:
# Add boundary and header
dataList.append('--' + boundary)
dataList.append('Content-Disposition: form-data; name={0}; filename={0}'.format(fileName))
fileType = mimetypes.guess_type(fileName)[0] or 'application/octet-stream'
dataList.append('Content-Type: {}'.format(fileType))
dataList.append('')
with open(fileName) as f:
# Bad for large files
dataList.append(f.read())
dataList.append('--'+boundary+'--')
dataList.append('')
contentType = 'multipart/form-data; boundary={}'.format(boundary)
body = '\r\n'.join(dataList)
headers = {'Content-type': contentType}
conn = http.client.HTTPConnection('http://...')
req = conn.request('POST', '/test/', body, headers)
print(conn.getresponse().read())
Есть две проблемы: это только текст и весь текст. файл должен храниться в памяти как гигантская строка.
Как загрузить любой двоичный файл? Есть ли способ сделать это, не считывая весь файл в память?
Подробнее здесь: https://stackoverflow.com/questions/157 ... st-request