跳转到主要内容
POST
/
v1
/
attachments
Upload files for Devin
curl --request POST \
  --url https://api.devin.ai/v1/attachments \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: multipart/form-data' \
  --form file=@example-file
"https://storage.devin.ai/attachments/xxx/file.py"
此接口会将文件上传到我们的服务器,并返回一个可在 Devin 会话中引用的 URL。文件不会自动发送到任何会话——你需要在提示中包含该 URL。

如何使用已上传文件

Devin 仅在附件按精确格式 ATTACHMENT:"{file_url}"(单数形式 ATTACHMENT,全部大写)书写时才会识别。ATTACHMENT: 这一行必须在提示词中单独成行,并且 URL 必须用双引号括起来。仅仅包含原始 URL 而不使用此格式将不会生效。诸如 ATTACHMENTS:(复数形式)之类的变体也不会被识别。
要在 Devin 会话中引用已上传的文件:
  1. 上传文件,使用此端点获取一个 URL
  2. 在提示词中包含该 URL,在创建会话或发送消息时附上
  3. 正确格式化 URL,在提示词中单独一行写上 ATTACHMENT:"{file_url}"

完整示例

import os
import requests

DEVIN_API_KEY = os.getenv("DEVIN_API_KEY")

# 步骤 1:上传文件
with open("data.csv", "rb") as f:
    response = requests.post(
        "https://api.devin.ai/v1/attachments",
        headers={"Authorization": f"Bearer {DEVIN_API_KEY}"},
        files={"file": f}
    )
file_url = response.text

# 步骤 2:创建引用已上传文件的会话
session_response = requests.post(
    "https://api.devin.ai/v1/sessions",
    headers={"Authorization": f"Bearer {DEVIN_API_KEY}"},
    json={
        "prompt": f"""请分析附件中的 CSV 文件数据并生成摘要报告。
重点关注趋势和关键洞察。

ATTACHMENT:"{file_url}"
"""
    }
)

print(session_response.json())
重要说明: 在提示中,ATTACHMENT: 前缀必须单独成行,且 URL 必须用双引号括起来,格式需与上面的示例完全一致:ATTACHMENT:"{url}"。若要附加多个文件,请为每个文件分别添加一行 ATTACHMENT:"{file_url}"

Authorizations

Authorization
string
header
required

Body

multipart/form-data
file
file

Response