Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Was this page helpful?
您可以透過 Files API 上傳檔案並將其掛載到工作階段的容器中,以便為您的代理程式提供檔案。
所有 Managed Agents API 請求都需要 managed-agents-2026-04-01 beta 標頭。SDK 會自動設定 beta 標頭。
首先,使用 Files API 上傳檔案:
file = client.beta.files.upload(file=Path("data.csv"))
print(f"File ID: {file.id}")透過在建立工作階段時將上傳的檔案新增到 resources 陣列,將其掛載到容器中:
mount_path 是選用的,但請確保上傳的檔案具有描述性名稱,以便代理程式知道要尋找什麼。
將建立一個新的 file_id,用於參考工作階段中檔案的執行個體。這些副本不會計入您的儲存空間限制。
透過將項目新增到 resources 陣列來掛載多個檔案:
每個工作階段最多支援 100 個檔案。
您可以在建立工作階段後使用工作階段資源 API 新增或移除檔案。每個資源在新增(或列出)時都會傳回一個 id,您可以使用它進行刪除。
使用 resources.list 列出工作階段上的所有資源。若要移除檔案,請使用資源 ID 呼叫 resources.delete:
使用 Files API 列出限定於工作階段的檔案並下載它們。
代理程式可以處理任何檔案類型,包括:
.py、.js、.ts、.go、.rs 等).csv、.json、.xml、.yaml).txt、.md).zip、.tar.gz)- 代理程式可以使用 bash 提取這些檔案掛載在容器中的檔案是唯讀副本。代理程式可以讀取它們,但無法修改原始上傳的檔案。若要使用修改後的版本,代理程式會寫入容器內的新路徑。
/ 開頭)session = client.beta.sessions.create(
agent=agent.id,
environment_id=environment.id,
resources=[
{
"type": "file",
"file_id": file.id,
"mount_path": "/workspace/data.csv",
},
],
)resources = [
{"type": "file", "file_id": "file_abc123", "mount_path": "/workspace/data.csv"},
{"type": "file", "file_id": "file_def456", "mount_path": "/workspace/config.json"},
{"type": "file", "file_id": "file_ghi789", "mount_path": "/workspace/src/main.py"},
]resource = client.beta.sessions.resources.add(
session.id,
type="file",
file_id=file.id,
)
print(resource.id) # "sesrsc_01ABC..."listed = client.beta.sessions.resources.list(session.id)
for entry in listed.data:
print(entry.id, entry.type)
client.beta.sessions.resources.delete(resource.id, session_id=session.id)# List files associated with a session
files = client.beta.files.list(
scope_id="sesn_abc123",
betas=["managed-agents-2026-04-01"],
)
for f in files:
print(f.id, f.filename)
# Download a file
content = client.beta.files.download(files.data[0].id)
content.write_to_file("output.txt")