• Home

  • Productivity

  • App tips

App tips

17 min read

How to create an OpenAI API key and use the OpenAI API

By Miguel Rebelo · July 8, 2024
Hero image of the OpenAI app logo on a light purple background.

OpenAI combined a powerful AI model and a chatbot experience—and the rest is history. But ChatGPT may not be best for your workflow, especially when you want to automate your AI prompts with complete flexibility.

With the OpenAI API, you can send your requests directly to OpenAI's AI models. You'll get the responses straight inside your software or platform of choice, so you can store, use, or combine that data—and even pull it into your own product, so your customers can have the power of OpenAI inside your app.

This complete guide explores all the features of the OpenAI API. There's also a step-by-step guide on how to use the OpenAI API—including how to create an OpenAI API key—and start integrating it into your apps. 

If you're looking to connect the OpenAI models to the apps you use at work, you can do it without any API setup. Learn more about how Zapier can add AI to your existing workflows.

Before you begin: How to use an API

If you have a basic understanding of how software works, you'll have an ok time following this API connection tutorial. If not, you may need a few extra resources.

I'd suggest starting with Zapier's article on how to use an API to understand how methods, calls, and responses work. On top of that, look up (or ask ChatGPT) what JSON is and how it helps computers communicate over APIs without errors. Don't worry—It's not code: it's simply a data notation language.

If APIs and JSON are familiar concepts to you, let's begin.

Table of contents:

  • What is the OpenAI API?

  • What can you do with the OpenAI API?

  • OpenAI API pricing

  • How to create an OpenAI key and set up OpenAI API connections

  • Use Zapier to connect to OpenAI models

What is the OpenAI API?

The OpenAI API is an interface that offers connectors between OpenAI's AI models and your apps. When you call the API endpoints, you can pass your instructions—often with deeper settings than a ChatGPT prompt—and get the response back on the platform you're using to make the call. The features available, instructions, and results will vary depending on the model and endpoint you want to use.

Right now, the OpenAI API gives access to the following flagship models:

  • GPT-4o, the fastest and most affordable multimodal model

  • GPT-4, the previous high-intelligence model

  • GPT-3.5 Turbo, a fast model for simpler tasks

But that's not the end of it. OpenAI also has models that'll help you with image generation, speech recognition, or running complex tasks with simple agents.

What can you do with the OpenAI API?

GPT-4o (multimodal)

OpenAI's newest model, GPT-4o, is multimodal, which means it can take in multiple data types, including text, audio, and images. It can read text, hear audio, and see images with impressive accuracy, and it can also respond with any combination of media depending on the request.

Text generation

Beyond GPT-4o, OpenAI has two models that focus on text generation.

For basic reasoning tasks and simple questions, GPT-3.5 Turbo offers a fast, cost-effective option when you need to analyze text, do a quick sentiment analysis, or categorize data.

If you need more intelligence, GPT-4 used to be the go-to model for higher-quality reasoning and responses. However, with the release of GPT-4o, this model is no longer the fastest, most intelligent, or most efficient.

Function calling

Function calling lets AI models use tools and interact with other APIs to run actions across external systems. For example, when you ask ChatGPT to visit a website in the chat, the model uses function calling to run a search and get the results.

When configured correctly, you can update data, run logic, or start complex workflows in any system you have access to, making it easier to automate actions across your work apps or enterprise platforms.

Function calling is available for both GPT-4o and GPT-4 models.

Embeddings

Embeddings help AI models understand the context of a prompt, improving the output quality. For example, if you're creating an AI text adventure, you can run a request to the embeddings API for the words "forest," "wolves," and "treasure." Then, when the user asks to continue the story, and you pass those embeddings with the prompt, the story will include those three elements instead of others.

Fine-tuning

Fine-tuning is training a GPT model with your data, so you can use it for more specific tasks. This adjusts the entire model based on your dataset, meaning you don't have to use long system instructions or prompts to get the best results. It's an expensive and time-consuming process reserved for machine learning professionals—or perhaps a very persistent and resourceful techie like you?

Image generation

DALL·E 3, the latest version of OpenAI's image generator, can take a text prompt and turn it into any kind of image you'd like. Its predecessor, DALL·E 2, also has basic image editing abilities and can create variations of an original image.

Text-to-speech and speech-to-text

Here, GPT-4o can reliably run both tasks, but it may be too expensive to use it. If you're looking for more efficiency, you can use the regular TTS model for performance tasks and TTS HD for higher-quality results.

Speech recognition

If you need to detect speech or language and translate what's being said, the Whisper model can help. While there's an open source version you can use on your infrastructure, the OpenAI API offers better performance.

Moderation

Running a community? You can use the moderation API to analyze user-generated content and score it for categories such as hate, threat, self-harm, or violence. The API returns a score you can bring into your system to flag offensive messages or automatically hide them.

Assistants

OpenAI Assistants are almost AI agents: they can run tasks that involve function calling, code interpretation, and file search. Using a thread to collaborate with the user or other assistants, they'll keep moving forward until they meet the objective.

Find inspiration in the OpenAI library

OpenAI has an example library with prompts you can copy or tweak depending on your needs. Here are some prompt examples you'll find there:

  • A Socratic tutor to drill down on complex topics with the power of questioning

  • Summarize for a 2nd grader to make everything understandable

  • A pro and con discusser to help you make big decisions

Brainstorm new use cases in the OpenAI playground

The OpenAI playground

Prompt engineering is a fundamental part of interacting with the OpenAI API. Optimizing the prompts you're passing in the API call will improve the output quality. The OpenAI Playground can help you brainstorm the best system instructions, and it offers advanced tools to help you change elements:

  • Temperature changes the model's creativity level

  • Frequency penalties determine how varied should the responses be

  • Presence penalties control how much the model will stay on topic

It's not just about playing with the generative models. You'll be able to access other features such as the Assistants playground, the fine-tuning interface, and file storage, among other things. Take a look at the left-side menu to see everything.

Spend some time running your experiments here. Once you find a collection of prompts that give you consistent results, start saving them in a document. You'll need to input them as part of the API call—which I'll get into very soon.

OpenAI API pricing

The OpenAI API runs a pay-as-you-go pricing structure. This means that you get charged based on the content type, length, or task that you pass on to an AI model, as well as the output it generates.

Here's the gist of the pricing so you know what to expect.

OpenAI API pricing for text generation

Pricing is done by million tokens (around 750,000 words), with different pricing for input and output.

  • GPT-4o: input at $5 per million tokens, output at $15 per million tokens.

  • GPT-3.5 Turbo: input at $0.50 per million tokens, output at $1.50 per million tokens

GPT-4o computer vision pricing

This is the model that can "see" images. Pricing is by image size and resolution, with each 768x768 image costing $0.003825.

OpenAI API embedding pricing

Large embedding tasks will cost you $0.13 per million tokens.

OpenAI API fine-tuning pricing

Fine-tuning a GPT-3.5 model will cost $8 per training with a million tokens, $3 for input, and $6 for output.

OpenAI API pricing for image generation 

Each DALL·E 3 HD image at the highest resolution will cost you $0.12.

OpenAI API pricing for audio

Whisper costs $0.006 per minute of audio processed. TTS standard goes for $15 and TTS HD for $30, both per million characters (not tokens).

OpenAI Assistants API pricing

Here you'll pay per task, with each code interpreter run costing $0.03 per session and file search costing $0.10 per vector-storage GB.

Managing your OpenAI billing and credits

To connect to these models and run tasks, you need to add a payment method and buy credit in advance. Then, as you run calls with your API key, you'll see the costs on your OpenAI account page, and your balance will be reduced according to usage.

How to set up OpenAI API connections

Grab some snacks, set your phone to Do Not Disturb, and let's start cooking.

  1. Create an OpenAI account

  2. Create a project (optional)

  3. Generate a new OpenAI API key

  4. Add credits to your OpenAI account

  5. Open the API documentation and reference

  6. Build a new request

  7. Set up authorization with your API key

  8. Pass your prompts

  9. Add more details to the request

  10. Integrate it with your apps

Step 1: Create an OpenAI account

If you haven't already, go to the OpenAI platform, and create an account.

Step 2: Create a project (optional)

You're logged in. Before we move to grabbing our API keys, you can organize them by project if you'd like. This lets you collaborate with your team, set custom billing limits, and have better visibility over usage. 

If you want to use this feature, on the top left of the screen, click Default project and then Create project. (You can also access the Organization overview page from here.)

Creating a default project with the OpenAI API

Step 3: Create an OpenAI API key

Since the OpenAI API isn't free, you need to create an API key so the platform knows who you are and who to bill the work to. To generate an OpenAI API key, look to top-right side of the screen, and click Dashboard.

The Dashboard button in the OpenAI playground

This is the OpenAI Playground that I mentioned before. It has all the tools for testing and developing with the OpenAI API. After you read the welcome message pop-up, you can click Get Started to continue.

The Get started button in the OpenAI playground

Close the pop-up. On the left-side menu, click API keys.

The API keys button in the OpenAI playground

On the top right of the screen, click Create new secret key. Note: you can only create an API key once you verify your account with your phone number.

The Create new secret key button in the OpenAI playground

A pop-up appears with your API key settings. I'll walk you through all of these in just a second.

The OpenAI API key creation pop-up

On the Owned by radio buttons, choose one:

  • You is better for personal use. Check this option if you're going to be the only person making API calls. It's useful for integrating the OpenAI models with other apps you use that support API connections.

  • Service account is for team or organizational use. This adds more security layers on the OpenAI platform, so it's suitable if multiple people will be using this key for API calls through the app you're building.

Very important: Regardless of the settings here, you need to keep this API key safe at all times. If someone finds your key, they could use it themselves, consuming credits, ruining training jobs you have going on, or even using it as an attack vector if you have OpenAI Assistants plugged into your systems. If this happens, you can discard the affected key and generate a new one. Don't share this key with anyone who doesn't need it, and if you're publishing an app to the public web, be sure to read up on your API security best practices.

Under Name, give your API key an appropriate name or service name ID.

If you created a project to manage your API keys, click the dropdown to select it. Otherwise, you can leave it on its default setting.

The last setting lets you adjust the Permissions this key has:

  • All gives full access to all API features.

  • Restricted lets you choose which models and tasks this key has access to. For example, if you're only using text generation, you can set Model capabilities to Write and all others to None.

  • Read only blocks all writing requests, which is useful for pulling data into external systems.

Consider setting it to the lowest privilege level necessary to do what you need.

Once you've adjusted these settings, click Create secret key, and the platform will generate one for you. You won't be able to see this key again: copy and paste it to a safe place for now, and consider disposing of it after you've set up the call in the next step. 

The Save your key pop-up in the OpenAI API key creation process

Once you click Done, the new key is added to the list. You can always delete or edit the name or permissions going forward.

List of API keys in the OpenAI playground

Step 4: Add credits to your OpenAI account

You won't be able to use the API if you don't add a few credits. On the top right of the screen, click the cogwheel icon to go to the Settings page.

The Settings button in the OpenAI playground

On the left-side menu, click Billing.

The Billing button in the OpenAI playground settings

Follow the instructions to add a payment method: they're very similar to every other SaaS app you use. I bought $10 worth of credits to play around—you can do the same if you'd like.

The Add payment details button in the Billing section of the OpenAI playground

Once complete, you'll see your pay-as-you-go credit on the page.

The Billing page with $9.99 worth of credits

Click the Dashboard link on the top right to go back to the OpenAI platform.

The Dashboard button in the OpenAI playground

Step 5: Open the API documentation and reference pages

Making and structuring the API call varies based on the API features that you want to use. To understand how to proceed, you need to find:

  • The documentation page, which gives you a general overview of the API features and how to use them. Here's the documentation for the text generation feature.

  • The API reference page, which includes all the technical specifications you need to pack into the request. Here's the API reference for the chat completions endpoint (we'll use it to run a text generation job).

Leveraging everything the API offers means you'll have to become familiar with these pages over time. Always remember to come back and read a bit more if you're running into trouble or brainstorming a new use case. 

You can navigate back and forth between the documentation and API reference by using the links at the top right of the screen.

The Docs and API reference options in the OpenAI playground

For this example, I want to use the chat completions endpoint, so I'm going to navigate to the corresponding page in the API reference. First, we need to copy the endpoint URL (https://api.openai.com/v1/chat/completions) and make a mental note of the HTTP method, which in this case is POST.

The chat completions docs page with the POST URL in the OpenAI playground

Step 6:  Build a new request

To help you grasp how this works, I'll be using Postman, an API design platform, to make a call asking for a text generation task. But you can replicate the steps whether you're using code, an internal tool builder, or a no-code app builder.

If you want to follow along, create a free account in Postman. After logging in to the dashboard, on the New API Request tab, click New Request.

The New Request button in Postman

Paste the endpoint URL on the large input field at the top. Also click the dropdown displaying the GET method, and change it to POST.

The POST URL in the New Request section of Postman

Postman will offer to set up quick authentication for OpenAI: I recommend you skip this part for the sake of learning. Later, you can use all the shortcuts you want to save time.

Learning through mistakes, part 1

Setting up new API calls is more hike up a mountain than stroll on the beach: it takes effort and trial and error to make it to the top. Let's go step by step and make a few mistakes to understand how to handle obstacles. Click the Send button, and see what happens.

The Send button in Postman

We have an error: HTTP 401 Unauthorized means we don't have authorization to call this endpoint. On the console at the bottom of the screen, you'll see the OpenAI API platform returns an informative error message: we haven't passed our secret API key. The platform doesn't know who we are or who to bill the generation work to. 

The 401 Unauthorized error message in Postman

Step 7: Set up authorization with your OpenAI API key

Whenever you run into an error, the next best action to take is to go back to the API reference and documentation to understand how to fix it. In this case, we need to take a look at the API authorization page

On this page, OpenAI explains how to authenticate with the API endpoint.

OpenAI's explanation of how to authenticate

Postman has a dedicated tab for authentication: under the endpoint input field, click Authorization.

Clicking Authorization in Postman to authenticate the OpenAI API key

Expand the Auth Type dropdown and click Bearer Token. (We know it's a bearer token because of the "Authorization: Bearer OPENAI_API_KEY" rule from the documentation two images above.)

The Bearer Token selection in Postman

To the right of this dropdown, paste the secret API key that you got before.

The Token field in Postman

Learning through mistakes, part 2

That should solve authentication. Let's keep teasing the OpenAI API to learn how it works. Click the Send button again.

Clicking Send in Postman

Oops. Look at the response below the request.

The 400 Bad Request error in Postman when trying to make an API call

We're authenticated, but we still got an HTTP 400 Bad Request error: this means we didn't pass a request to the platform, or that our request misses mandatory parameters—in this case, the error message says we didn't choose an AI model. But that's not the only thing we didn't choose: we also passed an empty request. 

The API reference page has a request template we can use to solve this error. Back on the OpenAI create chat completion API reference page, take a look at the right side.

The chat completion reference page in the OpenAI API guide

This request includes cURL for people using a command line to send and receive data from servers. Here's a breakdown of what this example means:

curl https://api.openai.com/v1/chat/completions \

The cURL command followed by the endpoint link starts the command line connection to the endpoint URL. The backslash at the end here is to change the line for readability; it has no impact on the request.

 -H "Content-Type: application/json" \

 -H "Authorization: Bearer $OPENAI_API_KEY" \

The lines prefixed with -H flags are the request headers. These give additional context to the receiving server, letting it know how to process this call. In this case, we have the "Content-Type: application/JSON", which tells what kind of data we'll be passing and the "Authorization: Bearer", where you'd insert your API key for authentication. Since I'm using Postman, I don't need these headers. But depending on which platform you're using to make the call, you may need to pass them.

-d '{

    "model": "gpt-3.5-turbo-16k",

    "messages": [

      {

        "role": "system",

        "content": "You are a helpful assistant."

      },

      {

        "role": "user",

        "content": "Hello!"

      }

    ]

  }'

Finally, the -d flag prefixed line shows the request's data, also known as body or payload. Everything that follows this tag is written in JSON.

I'm going to copy the body of the request without the -d flag or the single quotes at the beginning and end. Be careful when copying: if a single character is missing or is added, the call will return an error.

Copying the entire request

Back in Postman, click on the Body tab. Then, on the radio selectors below, choose raw. Click on line 1 and paste the JSON there. 

Pasting the JSON into Postman from the API request documentation

When that's done, click the Send button.

The Send button in Postman

If you've followed all the steps to the letter until now, you'll see an HTTP 200 OK status code: your request was received and sent to the selected OpenAI model, and you've got a response. 

The 200 OK response from the OpenAI API

I've highlighted the status code as well as the reply I got from the AI model.

Note: Every request you're sending now consumes credit based on token usage.

Step 8: Pass your prompts

Ok, you can now send data to an OpenAI model via the API. But this isn't useful if you can't pass your own prompts, so let's change the values in the JSON body. Let me highlight the request values you can change:

The requests you can change in the OpenAI API call

Here's what each of these do:

  • "model": lets you select which AI model you want to use. In my example, I'm using GPT-3.5 Turbo (gpt-3.5-turbo-16k). You can select other models by writing their system name in the value field—for example, "gpt-4-turbo". See the full model list here.

  • "messages": determines what you're sending to the selected model. In this case, there are two sets of messages you're sending:

    • "role": "system", is used to pass the system instructions to the model, controlling how it's going to behave (like the instructions when building a new GPT). "content": "You are a helpful assistant" determines the system message. You can change the text in bold; leave all others as they are.

    • "role": "user", labels the following "content": "Hello!" pair as what the user is passing to the model. This is the equivalent of writing your prompt down in ChatGPT. You can change that text, but leave all others as they are.

With this info, let's make changes to the instructions and user message. Here's what I did:

Changing the content request in Postman

I changed the system message to "You are an entertainer. Whenever I ask you a question, ask it back at me in a funny way. The prompt is "What's the weather like today?"

Change the system message and the prompt to whatever you'd like to test, and click Send. In my case, I'm going to brace for some AI-powered humor.

The response from the OpenAI API in Postman

Look for the AI reply in the middle of the response body, right in front of the "content" key: "What's the weather like today? Are we dressing for a monsoon or a sauna?"

Success.

Step 9: Add more details to the request

Back on the OpenAI API reference, you'll notice multiple parameters in the article. 

The parameters in the OpenAI documentation

Adding these to the JSON request body will help you control how the model responds. Scroll down the page, and find the temperature parameter.

A description of temperature in the OpenAI documentation

This is a lot of important information packed into a small snippet:

  • temperature is the name of the parameter that you'll use.

  • number or null is the type of data you should write in the value. In this case, temperature only accepts numbers or requests without a value.

  • Optional notes that the API endpoint will not return an error if you don't pass this key.

  • Defaults to 1 shows the behavior that the system assumes if you don't specify a value.

The instructions show the kinds of accepted values, along with other usage tips.

Here's how we can change the JSON body to include the temperature key/value pair. Go to the Postman interface, and below the model parameter, write in:

"temperature": 1.8,

Temperature changes the randomness of the output nearly to the maximum level (1.8 out of 2 maximum). You can keep adding more parameters under temperature, as long as you follow the rules on allowed values. 

No matter how many more parameters you decide to add, be sure to respect the syntax, otherwise the call will return an error. If you're having trouble with formatting, you can use ChatGPT to review your JSON structure.

Step 10: Integrate it with your apps

These steps vary widely depending on which platform you're using to call the OpenAI API. If you're using a SaaS app that enables AI features when you enter your API key, usually all the configuration is handled by the app, and you don't need to do anything else.

But if you're using a no-code, low-code, or internal tool builder, you can use the response in multiple ways:

  • You can save any of the key/value pairs to your database. This is useful to keep track of data to show it later.

  • You can use the prompt's response to place it inside a message or document inside your app and discard all the other data.

  • You can improve existing business logic with AI features, using its summarization or reasoning capabilities to automate the process even more.

When connecting to external APIs, refer to the documentation of the platform you're using to make the calls. For example, the Bubble no-code builder has an API connector explaining how to replicate the process I've just shown within its platform.

Use Zapier to connect to OpenAI

Setting up API calls isn't a walk in the park. If you want to build faster, you can instead use Zapier to connect your work apps to OpenAI models using a no-code interface, with plenty of actions to configure anything from a simple sentiment analysis prompt to a complex full-blog-post-from-a-topic workflow. Here are few examples to get you started.

Learn more about how to effectively add AI to your Zapier workflows and how to automate OpenAI, or get started with one of these pre-made workflows.

Create email copy with OpenAI from new Gmail emails and save as drafts in Gmail

Create email copy with OpenAI from new Gmail emails and save as drafts in Gmail
  • Gmail logo
  • OpenAI (GPT-4, DALL-E, Whisper) logo
  • Gmail logo
Gmail + OpenAI (GPT-4, DALL-E, Whisper)

Get an AI-generated daily digest of your emails in Slack

Get an AI-generated daily digest of your emails in Slack
  • Gmail logo
  • Slack logo
Gmail + Formatter by Zapier + OpenAI (GPT-4, DALL-E, Whisper) + 2 more

Create transcripts of audio files with OpenAI's Whisper

Create transcripts of audio files with OpenAI's Whisper
  • Dropbox logo
  • OpenAI (GPT-4, DALL-E, Whisper) logo
  • Dropbox logo
Dropbox + OpenAI (GPT-4, DALL-E, Whisper)

Create images with DALL.E based on Slack messages and send as a channel message

Create images with DALL.E based on Slack messages and send as a channel message
  • Slack logo
  • OpenAI (GPT-4, DALL-E, Whisper) logo
  • Slack logo
Slack + OpenAI (GPT-4, DALL-E, Whisper)

Zapier is the leader in workflow automation—integrating with thousands of apps from partners like Google, Salesforce, and Microsoft. Use interfaces, data tables, and logic to build secure, automated systems for your business-critical workflows across your organization's technology stack. Learn more.

Empower your apps with the OpenAI API

ChatGPT is already amazing for so many use cases, but using the API raises the ceiling even further on what you can achieve. When you integrate these AI models into your apps, you can start automating, scaling, and even launching your own AI-powered products.

If you don't manage to get your API calls set up on your first try, don't get discouraged: as a non-techie, I needed dozens of hours of practice to understand what was going on in the very first API calls I made. Keep trying, and that HTTP 200 OK will be yours too.

Related reading:

  • How to build your own custom ChatGPT

  • What is GPT? Everything you need to know

  • ChatGPT vs. GPT: What's the difference?

  • How to use the Gemini API

  • How to use the Claude API

Get productivity tips delivered straight to your inbox

We’ll email you 1-3 times per week—and never share your information.

tags
mentioned apps

Related articles

Improve your productivity automatically. Use Zapier to get your apps working together.

Sign up
See how Zapier works
A Zap with the trigger 'When I get a new lead from Facebook,' and the action 'Notify my team in Slack'