DEV Community

Cover image for Top 10 Free APIs You Should Know
Amr Saafan for Nile Bits

Posted on • Originally published at nilebits.com

Top 10 Free APIs You Should Know

The use of APIs, or application programming interfaces, is crucial for creating contemporary software. They provide application-to-application communication, data sharing, and service access from different platforms and services. APIs may streamline your development process and save time whether you're creating a mobile app, web app, or other type of software. This article will examine ten free APIs that you should be aware of by 2024, provide code examples to help you understand how to use them, and go over some use cases.

Why Are APIs Important for Developers?

Through the provision of pre-made building pieces for your apps, APIs simplify the development process. To manage functions like payments, weather information, user identification, and much more, you may integrate current services rather than creating them from scratch. Startups, amateurs, and small enterprises that do not have the funds for premium services might benefit most from free APIs.

Here are the top 10 free APIs that you should know about:

  1. OpenWeather API

The OpenWeather API is one of the most popular free APIs for accessing real-time weather data. It allows you to retrieve current weather, forecasts, and historical weather data for any city or region.

Use Case

OpenWeather is great for applications that need real-time weather updates, such as travel apps, event planners, or environmental monitoring systems.

Code Example: Fetch Weather Data in Python

import requests

api_key = "your_api_key"
city = "London"
url = f"http://api.openweathermap.org/data/2.5/weather?q={city}&appid={api_key}"

response = requests.get(url)
weather_data = response.json()

print(f"City: {weather_data['name']}")
print(f"Weather: {weather_data['weather'][0]['description']}")
Enter fullscreen mode Exit fullscreen mode

Key Features:

Current weather data

Weather forecast for up to 16 days

Free tier includes 60 calls per minute

Reference: OpenWeather API Documentation

  1. GitHub API

The GitHub API is a fantastic tool for interacting with GitHub repositories. You can automate tasks like managing issues, pull requests, and even setting up webhooks for repository events.

Use Case

GitHub API is essential for developers working on open-source projects, automating repository management, and integrating version control functionality into their apps.

Code Example: Fetch GitHub Repo Details in JavaScript

const fetch = require('node-fetch');

const repo = 'nodejs/node';
const url = `https://api.github.com/repos/${repo}`;

fetch(url)
  .then(res => res.json())
  .then(data => {
    console.log(`Repo: ${data.name}`);
    console.log(`Stars: ${data.stargazers_count}`);
  });
Enter fullscreen mode Exit fullscreen mode

Key Features:

Access repository information

Manage issues and pull requests

Free tier provides unlimited access to public repositories

Reference: GitHub API Documentation

  1. NewsAPI

NewsAPI aggregates news articles from various sources and provides developers with easy access to real-time news and articles. This API is especially useful for news apps, content curation platforms, or market analysis tools.

Use Case

You can use NewsAPI to display the latest news headlines, search for specific topics, or filter news by categories like technology, politics, or sports.

Code Example: Fetch Top Headlines in Python

import requests

api_key = "your_api_key"
url = f"https://newsapi.org/v2/top-headlines?country=us&apiKey={api_key}"

response = requests.get(url)
news = response.json()

for article in news['articles']:
    print(f"Title: {article['title']}")
Enter fullscreen mode Exit fullscreen mode

Key Features:

Access to headlines from thousands of news sources

Filter news by topic, region, or publication

Free tier allows 1000 requests per day

Reference: NewsAPI Documentation

  1. Twitter API

The Twitter API allows developers to integrate real-time social media data from Twitter into their applications. You can fetch tweets, user profiles, and trends.

Use Case

Use Twitter API to monitor trends, fetch user tweets, or track engagement with specific hashtags or topics. It's especially helpful for social media dashboards, content marketing tools, and sentiment analysis.

Code Example: Fetch User Tweets in Python

import tweepy

api_key = "your_api_key"
api_secret = "your_api_secret"
auth = tweepy.AppAuthHandler(api_key, api_secret)
api = tweepy.API(auth)

tweets = api.user_timeline(screen_name="elonmusk", count=5)

for tweet in tweets:
    print(f"{tweet.user.screen_name}: {tweet.text}")
Enter fullscreen mode Exit fullscreen mode

Key Features:

Access public tweets and user data

Stream real-time tweets

Free tier provides access to public tweets

Reference: Twitter API Documentation

  1. CoinGecko API

CoinGecko API provides cryptocurrency market data, including live prices, trading volume, market cap, and historical data. It supports over 6000 cryptocurrencies.

Use Case

Ideal for cryptocurrency portfolio tracking apps, market analysis platforms, or integrating real-time price feeds into financial applications.

Code Example: Fetch Cryptocurrency Prices in Python

import requests

url = "https://api.coingecko.com/api/v3/simple/price?ids=bitcoin,ethereum&vs_currencies=usd"

response = requests.get(url)
data = response.json()

print(f"Bitcoin: ${data['bitcoin']['usd']}")
print(f"Ethereum: ${data['ethereum']['usd']}")
Enter fullscreen mode Exit fullscreen mode

Key Features:

Live cryptocurrency prices

Support for over 6000 cryptocurrencies

Free tier provides access to a variety of endpoints

Reference: CoinGecko API Documentation

  1. OpenAI API

The OpenAI API provides access to powerful AI models like GPT-4, allowing developers to build applications that generate text, answer questions, or even create conversational agents.

Use Case

OpenAI is perfect for creating AI-driven chatbots, content generation tools, or applications that need natural language processing (NLP) capabilities.

Code Example: Text Generation in Python

import openai

openai.api_key = "your_api_key"
prompt = "Explain the benefits of using APIs in web development."

response = openai.Completion.create(
  engine="text-davinci-003",
  prompt=prompt,
  max_tokens=100
)

print(response.choices[0].text.strip())
Enter fullscreen mode Exit fullscreen mode

Key Features:

AI-based text generation and processing

NLP capabilities for a variety of use cases

Free tier with limited requests

Reference: OpenAI API Documentation

  1. Firebase API

The Firebase API is a comprehensive platform for building and running web and mobile applications, offering real-time databases, authentication, hosting, and cloud functions.

Use Case

Firebase is great for real-time chat apps, user authentication, and cloud-based backends for mobile and web applications.

Code Example: Real-Time Database in JavaScript

const firebase = require('firebase/app');
require('firebase/database');

const firebaseConfig = {
  apiKey: "your_api_key",
  authDomain: "your_project.firebaseapp.com",
  databaseURL: "https://your_project.firebaseio.com",
};

firebase.initializeApp(firebaseConfig);

const db = firebase.database();
db.ref('users/').set({
  username: "John Doe",
  email: "johndoe@gmail.com"
});
Enter fullscreen mode Exit fullscreen mode

Key Features:

Real-time database

Authentication services

Free tier offers basic functionality for small-scale apps

Reference: Firebase API Documentation

  1. NASA API

The NASA API provides access to a vast collection of space data, including images, videos, and information about planets, stars, and other celestial objects.

Use Case

NASA API is ideal for educational apps, space-themed websites, and applications that visualize or use space data.

Code Example: Fetch NASA Image of the Day in Python

import requests

api_key = "your_api_key"
url = f"https://api.nasa.gov/planetary/apod?api_key={api_key}"

response = requests.get(url)
data = response.json()

print(f"Title: {data['title']}")
print(f"URL: {data['url']}")
Enter fullscreen mode Exit fullscreen mode

Key Features:

Access to space images and data

Variety of endpoints for different datasets

Free tier with unlimited access to public datasets

Reference: NASA API Documentation

  1. Jikan API

The Jikan API is a free API for accessing information on anime, manga, and characters from MyAnimeList.

Use Case

Jikan is a must-have API for developers working on anime-related apps or websites. It allows you to fetch detailed information about anime series, episodes, characters, and more.

Code Example: Fetch Anime Details in Python

import requests

anime_id = 1  # ID for the anime "Cowboy Bebop"
url = f"https://api.jikan.moe/v3/anime/{anime_id}"

response = requests.get(url)
data = response.json()

print(f"Title: {data['title']}")
print(f"Synopsis: {data['synopsis']}")
Enter fullscreen mode Exit fullscreen mode

Key Features:

Detailed anime and manga information

Supports filtering by genres, popularity, and airing status

Free tier provides unlimited access to all public endpoints

Reference: Jikan API Documentation

  1. Cat Facts API

The Cat Facts API is a fun and quirky API that provides random facts about cats. It’s a light-hearted API but can be a great addition to apps and websites that want to provide users with fun and interesting content.

Use Case

This API is perfect for entertainment apps, fun widgets, or even as a daily dose of fun facts for your users.

Code Example: Fetch Random Cat Fact in JavaScript

const fetch = require('node-fetch');

fetch('https://catfact.ninja/fact')
  .then(res => res.json())
  .then(data => {
    console.log(`Cat Fact: ${data.fact}`);
  });
Enter fullscreen mode Exit fullscreen mode

Key Features:

Random cat facts

Free tier provides unlimited access

Reference: Cat Facts API Documentation

Conclusion

APIs are powerful tools that can significantly enhance your application's capabilities without requiring you to build everything from scratch. The 10 free APIs covered in this post can help you add features like weather updates, cryptocurrency data, social media integration, and even AI-driven text generation to your apps.

These APIs not only offer free tiers but also provide robust documentation and easy-to-use interfaces for developers of all levels. Whether you're building a simple app or a complex platform, these APIs can help you save time and focus on building unique features for your users.

Integrating these APIs is just a matter of writing a few lines of code, as shown in the examples. Now that you know which APIs to explore, start experimenting with them to see how they can take your development process to the next level!

Top comments (0)