M Language Function to Call Open AI API from Power Query
I’ve published a new version of the fxOpenAI function for Power Query.
https://github.com/avatorl/M/blob/master/fx/fxOpenAI.m
How to use
= fxOpenAI("user prompt", "system prompt", "gpt-4o")
= fxOpenAI("user prompt")
System prompt is optional. Default system prompt: “You’re a helpful assistant”
Model code is optional. Default model: “gpt-4o-mini”
To use the function, replace <OPENAI_API_KEY> with your actual API key:
data:image/s3,"s3://crabby-images/b0d7c/b0d7c134b4dbd1b76bea910bd3d852e5056dc289" alt=""
Structured Output
This ensures that the GPT response is a valid JSON matching the desired JSON schema. Set structured_output
to true
and update _response_format
to define the expected JSON schema for structured output.
For example, if your prompt is:
"Translate this text into French, Italian, and German. Text to translate: " & [Text]
This is the GPT answer without enabling structured output:
data:image/s3,"s3://crabby-images/81049/810499698fc97f70aeaeba2a4107a07c8e419c5e" alt=""
Enable structured output:
data:image/s3,"s3://crabby-images/a0abc/a0abc2a9739195917f7c410e3643bd754ba5f39c" alt=""
Define the expected JSON schema for structured output:
data:image/s3,"s3://crabby-images/9f5c0/9f5c0045b1c1c1097f674e4a09d843bc3c312d5c" alt=""
This is the structured GPT answer:
data:image/s3,"s3://crabby-images/b2a1d/b2a1da8ddfe8683e3ceae4977862942b04dbf207" alt=""
Error Handling
If API returns a error, fxOpenAI function ensures that Power Query error message includes error description returned by the API.
For example, error message for invalid JSON schema for structured output:
data:image/s3,"s3://crabby-images/b9435/b9435b4cb752d6b5656a303655fac14c6e21b2bf" alt=""
Output
The function returns a record that includes the following fields:
Content – GPT response. Either text (structured output disabled) or record (structured output enabled)
FinishReason:
- “stop” means the API returned the full chat completion generated by the model without running into any limits.
- “length” means the conversation was too long for the context window.
- “content_filter” means the content was filtered due to policy violations.
FullResponse – GPT response with metadata (record), including usage data (number of input and output tokes).
data:image/s3,"s3://crabby-images/23621/236219ec19f035453e849aaf65f918a308778067" alt=""
data:image/s3,"s3://crabby-images/4708a/4708a0c4b215046ec40580328d9e7a9883d74d9c" alt=""