此接口会将文件上传到我们的服务器,并返回一个可在 Devin 会话中引用的 URL。文件不会自动发送到任何会话——你需要在提示中包含该 URL。
Devin 仅在附件按精确格式 ATTACHMENT:"{file_url}"(单数形式 ATTACHMENT,全部大写)书写时才会识别。ATTACHMENT: 这一行必须在提示词中单独成行,并且 URL 必须用双引号括起来。仅仅包含原始 URL 而不使用此格式将不会生效。诸如 ATTACHMENTS:(复数形式)之类的变体也不会被识别。
要在 Devin 会话中引用已上传的文件:
- 上传文件,使用此端点获取一个 URL
- 在提示词中包含该 URL,在创建会话或发送消息时附上
- 正确格式化 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}"。