Skip to content

Latest commit

 

History

History
69 lines (53 loc) · 1.98 KB

README.md

File metadata and controls

69 lines (53 loc) · 1.98 KB

youtube2notion

For whom prefers reading than watching

Example

YouTube Video Notion Page
YouTube Video Notion Page
https://youtu.be/REeROakzwfU https://www.notion.so/You-Will-Never-Be-Lazy-Again-Jim-Kwik-0894d54029404df7984650be014224f4

How it works

  1. Get a youtube video id, a notion token v2, a notion page id by user input
  2. Download the youtube video by youtube-dl
  3. Split the video into thumbnail images per second by ffmpeg
  4. Download the youtube video's subtitle data by youtube_transcript_api
  5. Generate a markdown formatted file with the thumbnail images and subtitle
  6. Upload the markdown to notion by md2notion

How to use

CLI

Run CLI

docker run --rm -it taehoio/youtube2notion youtube2notion.py

Run CLI with arguments

docker run --rm -it taehoio/youtube2notion youtube2notion.py YOUTUBE_VIDEO_ID -t NOTION_TOKEN_V2 -p NOTION_PAGE_URL -l SUBTITLE_LANGUAGE

API server

Run CLI

docker run -d -it --name youtube2notion -p 5000:5000 taehoio/youtube2notion app.py

Run with Docker compose

version: "2.1"
services:
  youtube2notion:
    image: taehoio/youtube2notion
    container_name: youtube2notion
    ports:
      - 5000:5000/tcp
    command:
      - app.py
    tty: true

Call API endpoint

curl --location --request POST 'http://localhost:5000/upload' \
--header 'Content-Type: application/json' \
--data-raw '{
    "video_id": "YOUTUBE_VIDEO_ID",
    "notion_token_v2": "NOTION_TOKEN_V2",
    "notion_page_url": "NOTION_PAGE_URL",
    "subtitle_language": "SUBTITLE_LANGUAGE"
}'