How to export prompt and response data
Export JSON annotations
# Set the export params to include/exclude certain fields.
export_params= {
"attachments": True,
"metadata_fields": True,
"data_row_details": True,
"project_details": True,
"label_details": True,
"performance_details": True,
"interpolated_frames": True
}
# Note: Filters follow AND logic, so typically using one filter is sufficient.
filters= {
"last_activity_at": ["2000-01-01 00:00:00", "2050-01-01 00:00:00"],
"workflow_status": "<wkf-status>"
}
export_task = project.export(params=export_params, filters=filters)
export_task.wait_till_done()
# Return JSON output strings from export task results/errors, one by one:
# Callback used for JSON Converter
def json_stream_handler(output: lb.BufferedJsonConverterOutput):
print(output.json)
if export_task.has_errors():
export_task.get_buffered_stream(
stream_type=lb.StreamType.ERRORS
).start(stream_handler=lambda error: print(error))
if export_task.has_result():
export_json = export_task.get_buffered_stream(
stream_type=lb.StreamType.RESULT
).start(stream_handler=json_stream_handler)
print("file size: ", export_task.get_total_file_size(stream_type=lb.StreamType.RESULT))
print("line count: ", export_task.get_total_lines(stream_type=lb.StreamType.RESULT))
# Set the export params to include/exclude certain fields. Make sure each of these fields are correctly grabbed
export_params= {
"attachments": True,
"metadata_fields": True,
"data_row_details": True,
"project_details": True,
"label_details": True,
"performance_details": True
}
# You can set the range for last_activity_at and label_created_at.
# For context, last_activity_at captures the creation and modification of labels, metadata, status, comments and reviews.
# Note: This is an AND logic between the filters, so usually using one filter is sufficient.
filters= {
"last_activity_at": ["2000-01-01 00:00:00", "2050-01-01 00:00:00"],
"workflow_status": "Done"
}
export_task = project.export_v2(params=export_params, filters=filters)
export_task.wait_till_done()
if export_task.errors:
print(export_task.errors)
export_json = export_task.result
print("results: ", export_json)
Prompt export format
Humans generate prompts
{
"feature_id": "cldne96y301wy13yd0wp5z87y",
"feature_schema_id": "cljg9my6h01000741aemmcln8",
"name": "sample_name",
"text_answer": {
"content": "sample text"
}
}
Response export formats
Response - Radio
{
"feature_id": "cldne96y201wq13ydu0qcc2up",
"feature_schema_id": "cljggfygv0chn070w1v131s3v",
"name": "sample_radio_name",
"radio_answer": {
"feature_id": "cldne96y201wr13yd23kr1pcr",
"feature_schema_id": "cljgggcs200083b6lqbpml10p",
"name": "first_radio_answer",
"classifications": []
}
}
Response - Checklist
{
"feature_id": "cldne96y201wu13ydohrclpra",
"feature_schema_id": "cljgegd1p07m4073cfmfy5xkx",
"name": "checklist_question",
"checklist_answers": [
{
"feature_id": "cldne96y301wv13ydatuxugbt",
"name": "first_checklist_answer",
"classifications": []
},
{
"feature_id": "cldne96y301ww13yds4zkk49u",
"name": "second_checklist_answer",
"classifications": []
},
{
"feature_id": "cldne96y301wx13ydvb5x2w6o",
"name": "third_checklist_answer",
"classifications": []
}
]
}
Response - Text
{
"feature_id": "cldne96y301wy13yd0wp5z87y",
"feature_schema_id": "cljg9my6h01000741aemmcln8",
"name": "sample_name",
"text_answer": {
"content": "sample text"
}
}
Sample project export
{
"data_row": {
"id": "clpvnouh04uyy0723mmru42qn",
"global_key": "clpvnou2v03js07xsghfo2nzc",
"row_data": "{\"type\":\"application/llm.prompt-response-creation\",\"version\":1}",
"details": {
"dataset_id": "clpvnou0z004c0724pd4cmw8g",
"dataset_name": "test-humans-generate-prompts-reponses-dataset",
"created_at": "2023-12-07T20:34:06.540+00:00",
"updated_at": "2023-12-07T20:34:06.815+00:00",
"last_activity_at": "2024-04-10T15:21:31.000+00:00",
"created_by": "[email protected]"
}
},
"media_attributes": {
"mime_type": "application/llm.prompt-response-creation"
},
"attachments": [],
"metadata_fields": [],
"projects": {
"clpvnotzb03jo07xs48r7ewka": {
"name": "Andrea-test-humans-generate-prompts-responses",
"labels": [
{
"label_kind": "Default",
"version": "1.0.0",
"id": "clutyida4041a07h4a8ojbu1g",
"label_details": {
"created_at": "2024-04-10T15:21:31.000+00:00",
"updated_at": "2024-04-10T15:21:31.000+00:00",
"created_by": "[email protected]",
"content_last_updated_at": "2024-04-10T15:21:31.137+00:00",
"reviews": []
},
"performance_details": {
"seconds_to_create": 28,
"seconds_to_review": 0,
"skipped": false
},
"annotations": {
"objects": [],
"classifications": [
{
"feature_id": "clutykado00013b6rw65zj51e",
"feature_schema_id": "clutyjef000xk07wfeurhc2qb",
"name": "Is this a shirt?",
"value": "Is this a shirt?",
"text_answer": {
"content": "Potentially this is a shirt, but keep in mind this is not a good quality prompt"
}
},
{
"feature_id": "clutykap700033b6rmmlkpo6u",
"feature_schema_id": "clutyjef000xm07wf5ym80ud6",
"name": "Yes",
"value": "yes",
"radio_answer": {
"feature_id": "clutykap700023b6rhktauyzc",
"feature_schema_id": "clutyjef000xn07wf6smvc54b",
"name": "Red shirt",
"value": "red_shirt",
"classifications": []
}
}
],
"relationships": []
}
}
],
"project_details": {
"ontology_id": "clpvnqsqz01kv07zydvbscxzq",
"task_id": "14b02ec0-71f3-4d1f-b720-c6318e9a9346",
"task_name": "Initial review task",
"batch_id": "00870bc0-9540-11ee-a202-8d3b90bd1707",
"batch_name": "batch_clpvnotzb03jo07xs48r7ewka",
"workflow_status": "IN_REVIEW",
"priority": 5,
"consensus_expected_label_count": 2,
"workflow_history": [
{
"action": "Move",
"created_at": "2024-04-10T15:21:31.517+00:00",
"created_by": "[email protected]",
"previous_task_name": "Initial labeling task",
"previous_task_id": "1d0062f9-dfd9-0f86-baed-823235868a8c",
"next_task_name": "Initial review task",
"next_task_id": "14b02ec0-71f3-4d1f-b720-c6318e9a9346"
},
{
"action": "Move",
"created_at": "2024-04-10T15:21:31.506+00:00",
"created_by": "[email protected]",
"next_task_name": "Initial labeling task",
"next_task_id": "1d0062f9-dfd9-0f86-baed-823235868a8c"
}
]
}
}
}
}