Skip to content

An Open Source Python alternative to NotebookLM's podcast feature: Transforming Multimodal Content into Captivating Multilingual Audio Conversations with GenAI

License

Notifications You must be signed in to change notification settings

danielsinewe/podcastfy

Β 
Β 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Podcastfy.ai πŸŽ™οΈπŸ€–

Open In Colab PyPi Status Downloads Issues Pytest Docker Documentation Status License GitHub Repo stars

An Open Source alternative to NotebookLM's podcast feature: Transforming Multimodal Content into Captivating Multilingual Audio Conversations with GenAI

podcastfy.mp4

Podcastfy is an open-source Python package that transforms multi-modal content (text, images) into engaging, multi-lingual audio conversations using GenAI. Input content includes websites, PDFs, YouTube videos, as well as images.

Unlike UI-based tools focused primarily on note-taking or research synthesis (e.g. NotebookLM ❀️), Podcastfy focuses on the programmatic and bespoke generation of engaging, conversational transcripts and audio from a multitude of multi-modal sources, enabling customization and scale.

Podcastfy is available as a Python package, CLI, REST API and Web App.

Star History Chart

Audio Examples πŸ”Š

This sample collection is also available at audio.com.

Images

Image Set Description Audio
Senecio, 1922 (Paul Klee) Connection of Civilizations (2017) by Gheorghe Virtosu Senecio, 1922 (Paul Klee) and Connection of Civilizations (2017) by Gheorghe Virtosu πŸ”Š
The Great Wave off Kanagawa, 1831 (Hokusai) Takiyasha the Witch and the Skeleton Spectre, c. 1844 (Kuniyoshi) The Great Wave off Kanagawa, 1831 (Hokusai) and Takiyasha the Witch and the Skeleton Spectre, c. 1844 (Kuniyoshi) πŸ”Š
Taylor Swift Mona Lisa Pop culture icon Taylor Swift and Mona Lisa, 1503 (Leonardo da Vinci) πŸ”Š

Text

Content Type Description Audio Source
Youtube Video YCombinator on LLMs Audio YouTube
PDF Book: Networks, Crowds, and Markets Audio book pdf
Research Paper Climate Change in France Audio PDF
Website My Personal Website Audio Website
Website + YouTube My Personal Website + YouTube Video on AI Audio Website, YouTube

Multi-Lingual Text

Language Content Type Description Audio Source
French Website Agroclimate research information Audio Website
Portuguese-BR News Article Election polls in SΓ£o Paulo Audio Website

Features ✨

  • Generate conversational content from multiple sources and formats (images, websites, YouTube, and PDFs).
  • Customize transcript and audio generation (e.g., style, language, structure, length).
  • Create podcasts from pre-existing or edited transcripts.
  • Leverage cloud-based and local LLMs for transcript generation (increased privacy and control).
  • Integrate with advanced text-to-speech models (OpenAI, ElevenLabs, and Microsoft Edge).
  • Provide multi-language support for global content creation.
  • Integrate seamlessly with CLI and Python packages for automated workflows.

Updates πŸš€

v0.2.3 release

  • Add support for running LLMs locally
  • Enable config for running podcastfy with no API KEYs
  • and more...

v0.2.2 release

  • Podcastfy is now multi-modal! Users can generate audio from images + text inputs!

v0.2.0 release

  • Users can now customize podcast style, structure, and content
  • Integration with LangChain for better LLM management

Quickstart πŸ’»

Prerequisites

  • Python 3.11 or higher
  • $ pip install ffmpeg (for audio processing)

Setup

  1. Install from PyPI $ pip install podcastfy

  2. Set up your API keys

Python

from podcastfy.client import generate_podcast

audio_file = generate_podcast(urls=["<url1>", "<url2>"])

CLI

python -m podcastfy.client --url <url1> --url <url2>

Usage πŸ’»

Experience Podcastfy with our HuggingFace πŸ€— Spaces app. (Note: This UI app is less extensively tested than the Python package.)

Customization πŸ”§

Podcastfy offers a range of customization options to tailor your AI-generated podcasts:

License

This software is licensed under Apache 2.0. Here are a few instructions if you would like to use podcastfy in your software.

Contributing 🀝

We welcome contributions! See Guidelines for more details.

Example Use Cases 🎧🎢

  1. Content Summarization: Busy professionals can stay informed on industry trends by listening to concise audio summaries of multiple articles, saving time and gaining knowledge efficiently.

  2. Language Localization: Non-native English speakers can access English content in their preferred language, breaking down language barriers and expanding access to global information.

  3. Website Content Marketing: Companies can increase engagement by repurposing written website content into audio format, providing visitors with the option to read or listen.

  4. Personal Branding: Job seekers can create unique audio-based personal presentations from their CV or LinkedIn profile, making a memorable impression on potential employers.

  5. Research Paper Summaries: Graduate students and researchers can quickly review multiple academic papers by listening to concise audio summaries, speeding up the research process.

  6. Long-form Podcast Summarization: Podcast enthusiasts with limited time can stay updated on their favorite shows by listening to condensed versions of lengthy episodes.

  7. News Briefings: Commuters can stay informed about daily news during travel time with personalized audio news briefings compiled from their preferred sources.

  8. Educational Content Creation: Educators can enhance learning accessibility by providing audio versions of course materials, catering to students with different learning preferences.

  9. Book Summaries: Avid readers can preview books efficiently through audio summaries, helping them make informed decisions about which books to read in full.

  10. Conference and Event Recaps: Professionals can stay updated on important industry events they couldn't attend by listening to audio recaps of conference highlights and key takeaways.

Contributors

contributors

Disclaimer

This tool is designed for personal or educational use. Please ensure you have the necessary rights or permissions before using content from external sources for podcast creation. All audio content is AI-generated and it is not intended to clone real-life humans!

↑ Back to Top ↑

About

An Open Source Python alternative to NotebookLM's podcast feature: Transforming Multimodal Content into Captivating Multilingual Audio Conversations with GenAI

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 94.5%
  • TeX 4.3%
  • Other 1.2%