Get your next remote job on LaraJobs.
Artificial Intelligence GPT

How to access and use GPT-4o's API, step by step

Benjamin Crozat
Published on May 13, 2024 2 comments Edit on GitHub
How to access and use GPT-4o's API, step by step

Introduction to GPT-4o

GPT-4o is the multimodal version of the famous GPT-4 Large Language Model made by OpenAI. Its capabilities are groundbreaking and it even manages to be faster and cheaper than its predecessor, GPT-4, despite also being more powerful.

GPT-4o can generate text outputs known as “completions” that can be used to build a range of applications like truly personal assistants, smart chatbots, grammar checkers, spam filters, code generators, and more! The list could go on forever. It’s also the best model for vision!

If you are unfamiliar with LLMs, take some time to get up to speed thanks to my simple-to-understand article about how LLMs such as GPT work.

Now, let’s dive into this step-by-step tutorial that will help you make your first requests to GPT-4o!

Only developers who paid for using OpenAI’s APIs can access the new GPT-4o model. Try GPT-3.5 Turbo instead: Start using GPT-3.5 Turbo’s API in 5 minutes.

Create an account to get your GPT-4o API key

  1. Create an account.

Creating an account on OpenAI

  1. Confirm your email address.
  2. Log in.
  3. Check for your free $5 of credits on this page. Be careful, once you used them, the API keys you will generate won’t work until you pay.

The free $5 of credit given to all new developers.

  1. Generate your first API key for GPT-4o. Be careful, it will only be displayed once. Copy and paste it into a password manager so it’s stored securely.
  2. Start using your API key with GPT-4o’s API! (Continue reading to learn how.)

API key generation on OpenAI

How to make your first request to GPT-4o

Requesting GPT-4o’s API is easy peazy and we’ll do it with curl this time. Obviously, the API can be requested thanks to the HTTP layer of your favorite programming language.

Here’s the process broken down into four very clear steps:

  1. Locate your GPT-4o API key: You should have generated this already if you followed the previous section. It usually looks like a long string of random numbers and letters. Make sure to keep it secure.

  2. Open your terminal: If you want to start experimenting with curl, open your terminal.

  3. Input the curl command: Curl is a command-line tool used to transfer data. For GPT-4o’s chat API, you could use a command like this:

curl -X POST \
	-H "Content-Type: application/json" \
	-H "Authorization: Bearer YOUR_API_KEY" \
	https://api.openai.com/v1/chat/completions -d \
	'{
		"model": "gpt-4o",
		"messages": [
			{
				"role": "system",
				"content": "You are an assistant."
			},
			{
				"role": "user",
				"content": "Hello!"
			}
		]
	}'
  • Replace YOUR_API_KEY with your actual API key.
  • The string after -d specifies the request body in JSON format. It gives the model “gpt-4o” (GPT-4o) and two messages: a system message that sets up the role of the assistant, and a user message.
  1. Run the command: After pressing enter, you should see a response from the API in your terminal window after a few seconds at most.

Remember, this is a basic example. You might want to adjust the request depending on your specific needs, such as including more messages in the conversation.

Learn more on the official API reference for Chat Completions.

Pro tip: One API call can accept up to 128,000 tokens with GPT-4o (gpt-4o). A token is a numerical representation of your text. All your messages as well as the output from the model cannot exceed this limit. And for those who don’t know, 1,000 tokens roughly equals 750 English words.

An example response of GPT-4o through its API.

How to enable the JSON mode with the GPT-4o API

You can now force GPT-4o (as well as GPT-4 Turbo and GPT-3.5 Turbo) to output JSON consistently thanks to the new JSON mode.

(Most people here know what JSON is, but for the others, JSON is a way of storing information that both people and computers can understand. It uses text to organize data into lists and sets of “name: value” pairs.)

Before, asking GPT-4 to output JSON was already possible. But you could randomly get text instead of the JSON you requested. The new JSON mode aims to stop that.

Using it is as simple as adding a new object, and setting a system message that instructs the model to reply with JSON (but keep reading, because there are a few gotchas):

curl -X POST \
	-H "Content-Type: application/json" \
	-H "Authorization: Bearer YOUR_API_KEY" \
	https://api.openai.com/v1/chat/completions -d \
	'{
		"model": "gpt-4o",
		"messages": [
			{
				"role": "system",
- 				"content": "You are an assistant."
+ 				"content": "You are an assistant, and you only reply with JSON."
			},
			{
				"role": "user",
				"content": "Hello!"
			}
- 		]
+ 		],
+ 		"response_format": {
+ 			"type": "json_object"
+ 		}
	}'
  1. As you can see, we added the following object:
"response_format": {
	"type": "json_object"
}
  1. We set GPT-4o’s system message to “You are an assistant, and you only reply with JSON.”, but it can be anything you want as long as “JSON” is mentioned. If you don’t do that, the API call will fail and throw the error “‘messages’ must contain the word ‘json’ in some form, to use ‘responseformat’ of type ‘jsonobject’.“
{
	"role": "system",
	"content": "You are an assistant, and you only reply with JSON."
}
  1. But be careful! While the model will now always output JSON, you will never be able to get 100% accuracy in its structure.

GPT-4o’s pricing

Pricing for GPT-4o can change, so please double check. That being said, at the time I’m writing these lines, GPT-4o’s pricing is $0.005 per 1,000 tokens for the input and $0.015 per 1,000 tokens for the output.

This is such good news for developers who want to build their dream tools for cheaper thanks to the best-known language model. I know I already have something planned. What about you?

By the way, here’s a table that compares GPT-4o’s pricing to older GPT-4 models:

Model Input Output
gpt-4o (128K context) $0.005 / 1K tokens $0.015 / 1K tokens
gpt-4-turbo (128K context) $0.01 / 1K tokens $0.03 / 1K tokens
gpt-4 (32K context) $0.06 / 1K tokens $0.12 / 1K tokens
 gpt-4 (8K context) $0.03 / 1K tokens $0.06 / 1K tokens

Ideas to build thanks to GPT-4o’s API

Artificial Intelligence with GPT-4o enables developers to build products we couldn’t hope to before. For instance, I created Nobinge, a tool that lets you summarize and chat with YouTube videos.

Here are a bunch of ideas to experiment with:

  • Additional AI-based features for existing products
  • Automated email responses
  • Chatbots
  • Content summarizers
  • Personal assistants
  • Personalized teaching programs
  • Sentiment analysis tools
  • Spam filters

And did you know OpenAI offers developers an API to add realistic voices to their projects?

Wait, there's more!

2 comments

Noe Ortiz
Noe Ortiz 2mos ago

What model do you recommend for audio to text transcriptions? I am using Azure, but my bill is very high.

Benjamin Crozat
Benjamin Crozat 2mos ago

Hello. You don't have a lot of choices there. The TTS-1 model will do. 🙂 https://benjamincrozat.com/openai-tts-api

Get help or share something of value with other readers!

Great deals for enterprise developers
  • Summarize and talk to YouTube videos. Bypass ads, sponsors, chit-chat, and get to the point.
    Try Nobinge →
  • Monitor the health of your apps: downtimes, certificates, broken links, and more.
    20% off the first 3 months using the promo code CROZAT.
    Try Oh Dear for free
  • Keep the customers coming; monitor your Google rankings.
    30% off your first month using the promo code WELCOME30
    Try Wincher for free →
The latest community links
- / -