Hướng dẫn này giải thích cách sử dụng phương thức download
trên tài nguyên Media
của API Google Chat để tải nội dung nghe nhìn (tệp) từ tin nhắn trong Google Chat xuống.
Khi người dùng gửi tin nhắn đến ứng dụng của bạn, Google Chat sẽ gửi một sự kiện tương tác MESSAGE
.
Sự kiện tương tác mà ứng dụng của bạn nhận được bao gồm một nội dung yêu cầu. Nội dung yêu cầu là tải trọng JSON đại diện cho sự kiện tương tác, bao gồm cả mọi tệp đính kèm. Dữ liệu trong tệp đính kèm khác nhau tuỳ thuộc vào việc tệp đính kèm đó là nội dung được tải lên (tệp trên máy) hay là tệp được lưu trữ trên Drive. Tài nguyên Media
đại diện cho một tệp được tải lên Google Chat, chẳng hạn như hình ảnh, video và tài liệu.
Tài nguyên Attachment
đại diện cho một bản sao của nội dung nghe nhìn (tệp) được đính kèm vào thông báo. Tài nguyên Attachment
bao gồm siêu dữ liệu về tệp đính kèm, chẳng hạn như vị trí lưu tệp.
Điều kiện tiên quyết
Python
- Python 3.6 trở lên
- Công cụ quản lý gói pip
Các thư viện ứng dụng mới nhất của Google dành cho Python. Để cài đặt hoặc cập nhật các trình mô phỏng, hãy chạy lệnh sau trong giao diện dòng lệnh:
pip3 install --upgrade google-api-python-client google-auth-oauthlib
- Một dự án trên Google Cloud đã bật và định cấu hình API Google Chat. Để biết các bước, hãy xem bài viết Tạo ứng dụng Google Chat.
Đã định cấu hình uỷ quyền cho ứng dụng Chat. Việc tải nội dung nghe nhìn xuống hỗ trợ cả:
- Xác thực người dùng bằng phạm vi uỷ quyền
chat.messages.readonly
hoặcchat.messages
. - Xác thực ứng dụng bằng phạm vi uỷ quyền
chat.bot
.
- Xác thực người dùng bằng phạm vi uỷ quyền
Tải xuống từ tệp đính kèm
Để tải nội dung nghe nhìn xuống từ một tệp đính kèm, hãy chuyển những nội dung sau vào yêu cầu:
- Với tính năng xác thực người dùng, hãy chỉ định phạm vi uỷ quyền
chat.messages.readonly
hoặcchat.messages
. Với tính năng xác thực ứng dụng, hãy chỉ định phạm vi uỷ quyềnchat.bot
. - Gọi các phương thức sau đây của Google Chat:
- Nhận
attachmentDataRef
bằng cách gọi một trong các phương thức sau: - Gọi phương thức
download
trên tài nguyênMedia
và chỉ địnhattachmentDataRef.resourceName
được truy xuất trước đó dưới dạngmedia.download.resourceName
.
- Nhận
Ví dụ sau đây tải xuống một tệp đính kèm với một thư:
Python
- Trong thư mục đang làm việc, hãy tạo một tệp có tên
chat_media_and_attachment_download.py
. Đưa mã sau vào
chat_media_and_attachment_download.py
:import io from google_auth_oauthlib.flow import InstalledAppFlow from googleapiclient.discovery import build from googleapiclient.http import MediaIoBaseDownload # Define your app's authorization scopes. # When modifying these scopes, delete the file token.json, if it exists. SCOPES = ["https://www.googleapis.com/auth/chat.messages"] def main(): ''' Authenticates with Chat API via user credentials, then downloads a file attached to a message. ''' # Authenticate with Google Workspace # and get user authorization. flow = InstalledAppFlow.from_client_secrets_file( 'client_secrets.json', SCOPES) creds = flow.run_local_server() # Build a service endpoint for Chat API. chat = build('chat', 'v1', credentials=creds) # Download media resource. request = chat.media().download_media( resourceName=RESOURCE_NAME, ) file = io.BytesIO() downloader = MediaIoBaseDownload(file, request) done = False while done is False: status, done = downloader.next_chunk() if status.total_size: print(f'Total size: {status.total_size}') print(f'Download {int(status.progress() * 100)}') if __name__ == '__main__': main()
Trong mã, hãy thay thế
RESOURCE_NAME
bằngattachmentDataRef.resourceName
. Bạn có thể truy xuất một trong các cách sau:- Phương thức
get
trên tài nguyênAttachment
. - Phương thức
get
trên tài nguyênMessage
. - Phương thức
list
trên tài nguyênMessage
.
- Phương thức
Trong thư mục đang làm việc, hãy tạo và chạy mẫu:
python3 chat_media_and_attachment_download.py
Nếu thành công, phương thức này sẽ trả về nội dung tệp dưới dạng byte.
Để tải nội dung tệp xuống, hãy chọn một trong những cách sau:
Bạn nên sử dụng lớp
MediaIoBaseDownload
trong Python, lớp này chứa các phương thức để tải tệp xuống theo từng phần và lưu nội dung vào luồng đầu ra.Nếu bạn phải thực hiện yêu cầu HTTP theo cách thủ công, hãy gọi phương thức
download
và chỉ định phần tệp bạn muốn tải xuống bằng cách sử dụng phạm vi byte với tiêu đềRange
, ví dụ:Range: bytes=500-999
.
Chủ đề có liên quan
- Nếu thông báo là một tệp trên Drive, hãy dùng API Drive để truy cập vào tệp đó.
- Tải nội dung nghe nhìn lên dưới dạng tệp đính kèm
- Tải nội dung nghe nhìn xuống dưới dạng tệp đính kèm
- Nhận siêu dữ liệu về tệp đính kèm tin nhắn