apps/opik-documentation/documentation/fern/docs-v2/observability/export_data.mdx
Opik gives you several ways to export the data you've logged — pick the one that fits your workflow.
The Python and TypeScript SDKs let you search and export traces, spans, and threads programmatically.
client = opik.Opik()
# Export all traces
traces = client.search_traces(project_name="Default project", max_results=1000000)
# Export filtered traces
traces = client.search_traces(
project_name="Default project",
filter_string='input contains "Opik"'
)
# Convert to dict if needed
traces = [trace.dict() for trace in traces]
```
const client = new Opik();
// Export all traces
const traces = await client.searchTraces({
projectName: "Default project",
maxResults: 1000000,
});
// Export filtered traces
const filtered = await client.searchTraces({
projectName: "Default project",
filterString: 'input contains "Opik"',
});
```
import opik
client = opik.Opik()
# Export spans by trace ID
spans = client.search_spans(
project_name="Default project",
trace_id="067092dc-e639-73ff-8000-e1c40172450f"
)
# Export filtered spans
spans = client.search_spans(
project_name="Default project",
filter_string='input contains "Opik"'
)
import opik
client = opik.Opik()
# Export all threads
threads = client.search_threads(project_name="Default project", max_results=1000000)
# Export filtered threads
threads = client.search_threads(
project_name="Default project",
filter_string='number_of_messages >= 5'
)
All search methods accept a filter_string / filterString using the Opik Query Language (OQL):
"<COLUMN> <OPERATOR> <VALUE> [AND <COLUMN> <OPERATOR> <VALUE>]*"
AND (OR is not supported)"2024-01-01T00:00:00Z")metadata.model, feedback_scores.accuracyCommon filter examples:
client.search_traces(filter_string='start_time >= "2024-01-01T00:00:00Z"')
client.search_traces(filter_string='usage.total_tokens > 1000')
client.search_traces(filter_string='metadata.model = "gpt-4o"')
client.search_traces(filter_string='feedback_scores.user_rating is_not_empty')
client.search_traces(filter_string='tags contains "production"')
The full list of supported columns per entity type is documented below.
Use the /traces and /spans endpoints to export data. Both endpoints are paginated.
Select the traces or spans you want to export in the Opik dashboard and click Export CSV in the Actions dropdown.
<Frame> </Frame> <Tip> The UI exports up to 100 traces or spans at a time. For larger exports use the SDK or CLI. </Tip>The opik export and opik import commands let you export traces, spans, datasets, prompts, and experiments for a project to local JSON or CSV files, and import them back — useful for migrations, backups, and cross-environment syncs. Every command is scoped to a single project, named right after the workspace.
On disk, folders and files are keyed by ID: data lands under <path>/<workspace>/projects/<project_id>/, with a project.json ({"id", "name"}) and id-named item files (dataset_<id>.json, prompt_<id>.json, experiment_<id>.json, trace_<id>.json). Human names are stored as data inside the files — this keeps paths free of /, :, and spaces. You still pass project and item names on the command line; the CLI resolves names ↔ IDs for you.
opik export WORKSPACE PROJECT ITEM [NAME] [OPTIONS]
ITEM is one of: all, dataset, traces, experiment, prompt
# Export everything in a project
opik export my-workspace my-project all
# Export the project's traces
opik export my-workspace my-project traces
# Export a specific dataset
opik export my-workspace my-project dataset "my-test-dataset"
# Export with a date filter
opik export my-workspace my-project traces \
--filter 'created_at >= "2024-01-01T00:00:00Z"'
# Export as CSV for analysis
opik export my-workspace my-project traces --format csv --path ./csv_data
opik import WORKSPACE PROJECT ITEM [NAME] [OPTIONS]
# Import a dataset
opik import my-workspace my-project dataset "my-dataset"
# Import the project's traces
opik import my-workspace my-project traces
# Preview what would be imported
opik import my-workspace my-project all --dry-run
# Import into a different (renamed or scratch) destination project
opik import my-workspace my-project all --to-project my-restore
The project name is matched against the name recorded in each exported project.json. Import uses the same --path as export (both resolve <path>/<workspace>/projects/<id>/), so no path juggling is needed. Use --to-project <NAME> to import into a different destination project (default: the source project's name).
Imports are automatically resumable — if interrupted, re-run the same command and it picks up where it left off using a local migration_manifest.db.
# Step 1: Export from source (use source credentials)
# Writes to ./migration_data/my-workspace/projects/<project_id>/
OPIK_API_KEY=<source_key> OPIK_URL_OVERRIDE=https://source.opik.example.com \
opik export my-workspace my-project all --path ./migration_data
# Step 2: Import to destination (use destination credentials)
# Same --path as export — import resolves <path>/my-workspace/projects/<id>/.
OPIK_API_KEY=<dest_key> OPIK_URL_OVERRIDE=https://dest.opik.example.com \
opik import my-workspace my-project all --path ./migration_data
See the CLI help (opik export --help / opik import --help) for all options and troubleshooting.