Chat through the OpenAI-compatible interface
After uploading files to an assistant, you can chat with the assistant.
This page shows you how to chat with an assistant using the OpenAI-compatible chat interface. This interface is based on the OpenAI Chat Completion API, a commonly used and adopted API. It is useful if you need inline citations or OpenAI-compatible responses, but has limited functionality compared to the standard chat interface.
The standard chat interface is the recommended way to chat with an assistant, as it offers more functionality and control over the assistant’s responses and references.
Chat with an assistant
The OpenAI-compatible chat interface can return responses in two different formats:
- Default response: The assistant returns a response in a single string field, which includes citation information.
- Streaming response: The assistant returns the response as a text stream.
Default response
The following example sends a message and requests a response in the default format:
The content
parameter in the request cannot be empty.
The example above returns a result like the following:
Streaming response
The following example sends a messages and requests a streaming response:
The content
parameter in the request cannot be empty.
The example above returns a result like the following:
There are three types of messages in a chat completion response:
- Message start: Includes
"role":"assistant"
, which indicates that the assistant is responding to the user’s message. - Content: Includes a value in the
content
field (e.g.,"content":"The"
), which is part of the assistant’s streamed response to the user’s message. - Message end: Includes
"finish_reason":"stop"
, which indicates that the assistant has finished responding to the user’s message.
Extract the response content
The assistant’s response is returned in a JSON response object along with other information. The message string is contained in the following JSON object:
choices.[0].message.content
for the default chat responsechoices[0].delta.content
for the streaming chat response
You can extract the message content and print it to the console:
This creates output like the following:
Was this page helpful?