Hướng dẫn python requests file upload content-type - python yêu cầu loại nội dung tải lên tệp

Nếu bạn làm cho mỗi thông số tệp thành một tuple, bạn có thể chỉ định loại MIME là tham số thứ ba:

files = {
    'file1': ['foo.gif', open['foo.gif', 'rb'], 'image/gif'],
    'file2': ['bar.png', open['bar.png', 'rb'], 'image/png'],
}
response = requests.post[url, files=files]

Bạn cũng có thể đưa ra một tham số thứ 4, đó phải là một từ điển với các tiêu đề bổ sung cho mỗi phần.

Xem tài liệu API yêu cầu:

$ python3 -m venv .
7 có thể là 2-Tuple
$ python3 -m venv .
8, 3-Tuple
$ python3 -m venv .
9 hoặc 4-Tuple
$ . bin/activate
0, trong đó
$ . bin/activate
1 là một chuỗi xác định loại nội dung của tệp đã cho và
$ . bin/activate
2 Một đối tượng giống như dict có chứa các tiêu đề bổ sung để thêm vào tệp.

Giới thiệu

Python được hỗ trợ bởi nhiều thư viện giúp đơn giản hóa việc truyền dữ liệu qua HTTP. Thư viện

$ . bin/activate
3 là một trong những gói Python phổ biến nhất vì nó được sử dụng rất nhiều trong việc quét web. Nó cũng phổ biến để tương tác với máy chủ! Thư viện giúp dễ dàng tải lên dữ liệu theo định dạng phổ biến như JSON, nhưng cũng giúp bạn dễ dàng tải lên các tệp.

Trong hướng dẫn này, chúng tôi sẽ xem xét cách tải lên các tệp bằng thư viện

$ . bin/activate
3 của Python. Bài viết sẽ bắt đầu bằng cách bao gồm thư viện
$ . bin/activate
3 và chữ ký chức năng
$ . bin/activate
6. Tiếp theo, chúng tôi sẽ bao gồm cách tải lên một tệp duy nhất bằng gói
$ . bin/activate
3. Cuối cùng nhưng không kém phần quan trọng, chúng tôi tải lên nhiều tệp trong một yêu cầu.

Tải lên một tệp duy nhất với thư viện yêu cầu của Python

Hướng dẫn này bao gồm cách gửi các tệp, chúng tôi không quan tâm đến cách chúng được tạo. Để làm theo, tạo ba tệp được gọi là

$ . bin/activate
8,
$ . bin/activate
9 và
$ pip install requests
0.

Điều đầu tiên chúng tôi cần làm là cài đặt thư viện

$ pip install requests
1 của chúng tôi trong không gian làm việc của chúng tôi. Mặc dù không cần thiết, bạn nên cài đặt thư viện trong môi trường ảo:

$ python3 -m venv .

Kích hoạt môi trường ảo để chúng ta không còn tác động đến việc cài đặt Python toàn cầu:

$ . bin/activate

Bây giờ chúng ta hãy cài đặt thư viện

$ . bin/activate
3 với
$ pip install requests
3:

$ pip install requests

Tạo một tệp mới có tên

$ pip install requests
4 sẽ lưu trữ mã của chúng tôi. Trong tệp đó, hãy bắt đầu bằng cách nhập thư viện
$ . bin/activate
3:

import requests

Bây giờ chúng tôi đã thiết lập để tải lên một tập tin! Khi tải lên một tệp, chúng ta cần mở tệp và truyền phát nội dung. Rốt cuộc, chúng tôi không thể tải lên một tệp mà chúng tôi không có quyền truy cập. Chúng tôi sẽ làm điều này với chức năng

$ pip install requests
6.

Hàm

$ pip install requests
6 chấp nhận hai tham số: đường dẫn của tệp và chế độ. Đường dẫn của tệp có thể là một đường dẫn tuyệt đối hoặc đường dẫn tương đối đến nơi tập lệnh đang được chạy. Nếu bạn đang tải lên một tệp trong cùng một thư mục, bạn chỉ có thể sử dụng tên của tệp.

Đối số thứ hai, chế độ, sẽ lấy giá trị "đọc nhị phân" được biểu thị bằng

$ pip install requests
8. Đối số này nói với máy tính rằng chúng tôi muốn mở tệp ở chế độ đọc và chúng tôi muốn tiêu thụ dữ liệu của tệp ở định dạng nhị phân:

test_file = open["my_file.txt", "rb"]

Lưu ý: Điều quan trọng là phải đọc tệp ở chế độ nhị phân. Thư viện

$ . bin/activate
3 thường xác định tiêu đề
import requests
0, là giá trị trong byte. Nếu tệp không được đọc trong chế độ byte, thư viện có thể nhận được giá trị không chính xác cho
import requests
0, điều này sẽ gây ra lỗi trong quá trình gửi tệp.
: it's important to read the file in binary mode. The
$ . bin/activate
3 library typically determines the
import requests
0 header, which is a value in bytes. If the file is not read in bytes mode, the library may get an incorrect value for
import requests
0, which would cause errors during file submission.

Đối với hướng dẫn này, chúng tôi sẽ thực hiện các yêu cầu cho dịch vụ HTTPBIN miễn phí. API này cho phép các nhà phát triển kiểm tra các yêu cầu HTTP của họ. Hãy tạo một biến lưu trữ URL, chúng tôi sẽ đăng các tệp của chúng tôi lên:

test_url = "//httpbin.org/post"

Bây giờ chúng tôi có mọi thứ để đưa ra yêu cầu. Chúng tôi sẽ sử dụng phương thức

$ . bin/activate
6 của thư viện
$ . bin/activate
3 để tải lên tệp. Chúng tôi cần hai đối số để thực hiện công việc này: URL của thuộc tính máy chủ và
import requests
4. Chúng tôi cũng sẽ lưu phản hồi trong một biến, viết mã sau:

test_response = requests.post[test_url, files = {"form_field_name": test_file}]

Tài sản

import requests
4 lấy một từ điển. Khóa là tên của trường biểu mẫu chấp nhận tệp. Giá trị là byte của tệp đã mở mà bạn muốn tải lên.

Thông thường để kiểm tra xem phương thức

$ . bin/activate
6 của bạn có thành công không, chúng tôi kiểm tra mã trạng thái HTTP của phản hồi. Chúng ta có thể sử dụng thuộc tính
import requests
7 của đối tượng phản hồi,
import requests
8. Nếu đó là sự thật, chúng tôi sẽ in ra phản hồi từ máy chủ HTTP, trong trường hợp này, nó sẽ lặp lại yêu cầu:

Kiểm tra hướng dẫn thực hành của chúng tôi, thực tế để học Git, với các thực hành tốt nhất, các tiêu chuẩn được công nghiệp chấp nhận và bao gồm bảng gian lận. Ngừng các lệnh git googling và thực sự tìm hiểu nó!

if test_response.ok:
    print["Upload completed successfully!"]
    print[test_response.text]
else:
    print["Something went wrong!"]

Hãy thử nó! Trong thiết bị đầu cuối, thực thi tập lệnh của bạn bằng lệnh

import requests
9:

python single_uploader.py

Đầu ra của bạn sẽ tương tự như thế này:

$ python3 -m venv .
0

Khi kiểm tra Sanity, bạn có thể xác minh giá trị

test_file = open["my_file.txt", "rb"]
0 khớp với những gì trong tệp của bạn.

Tải lên nhiều tệp với thư viện yêu cầu của Python

Tải lên nhiều tệp bằng cách sử dụng các yêu cầu khá giống với một tệp duy nhất, với sự khác biệt chính là việc chúng tôi sử dụng danh sách. Tạo một tệp mới có tên

test_file = open["my_file.txt", "rb"]
1 và mã thiết lập sau:

$ python3 -m venv .
1

Bây giờ, hãy tạo một biến có tên là

test_file = open["my_file.txt", "rb"]
2 là từ điển có nhiều tên và tệp:

$ python3 -m venv .
2

Giống như trước đây, các khóa là tên của các trường biểu mẫu và các giá trị là các tệp trong byte.

Chúng tôi cũng có thể tạo các biến tệp của chúng tôi như một danh sách các bộ dữ liệu. Mỗi tuple chứa tên của trường biểu mẫu Chấp nhận tệp, theo sau là nội dung của tệp trong byte:

$ python3 -m venv .
3

Hoặc là hoạt động nên chọn bất cứ thứ gì bạn thích!

Khi danh sách các tệp đã sẵn sàng, bạn có thể gửi yêu cầu và kiểm tra phản hồi của nó như trước:

$ python3 -m venv .
4

Thực hiện tập lệnh này bằng lệnh

import requests
9:

$ python3 -m venv .
5

Bạn sẽ thấy đầu ra này:

$ python3 -m venv .
6

Làm tốt lắm! Bạn có thể tải lên một và nhiều tệp với

$ . bin/activate
3!

Sự kết luận

Trong bài viết này, chúng tôi đã học cách tải lên các tệp trong Python bằng thư viện

$ . bin/activate
3. Trong đó đó là một tệp hoặc nhiều tệp, chỉ cần một vài điều chỉnh với phương thức
$ . bin/activate
6. Chúng tôi cũng đã xác minh phản hồi của chúng tôi để đảm bảo rằng tải lên của chúng tôi đã thành công.

Bài Viết Liên Quan

Chủ Đề