Skip to content

wu4f/gdoc2site

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

59 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gdoc2site

gdoc2site is a Python script that exports every tab in a Google Doc as a standalone HTML page. Each tab is saved to a separate HTML file containing styling provided by a shared Jinja2 template in base.html.


✨ Features

  • Exports each tab from a Google Doc to its own HTML file
  • Supports exporting:
    • All tabs
    • A single tab (via command-line argument)
  • Handles OAuth authentication automatically (stores token.json)
  • Extracts the <body> content from Google’s HTML export
  • Cleans wrapped Google redirect links (e.g., https://www.google.com/url?q=...)
  • Applies a Jinja2-based HTML template (base.html) to each exported page
  • Outputs each page to website/ directory

📦 Setup

  • Clone repository, create virtual environment, and install dependencies:
git clone https://github.com/wu4f/gdoc2site
cd gdoc2site
virtualenv -p python3 env
source env/bin/activate
pip install -r requirements.txt
  • Create OAuth Credentials
    • Create Google Cloud Project and Enable Google Docs and Drive APIs
    • APIs & Services -> Credentials
    • OAuth Client ID -> Desktop Application
    • Download JSON credential file and save it in credentials.json
    • The first run will launch a browser window for authentication and create token.json.

▶️ Usage

  • Export all tabs
python gdoc2site.py <DOC_ID>
  • Export specific tab (exports only the tab with the matching ID)
python gdoc2site.py <DOC_ID> <TAB_ID>

About

Converts a Google Doc with a collection of Tabs into a web site

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors