Skip to content

SajjadTalks/blog

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

41 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

πŸ“ Python Static Blog Generator

This is a simple, fast, and customizable static blog generator written in Python. It reads Markdown posts with optional metadata, converts them into static HTML pages using Jinja2 templates, and deploys the site to GitHub Pages automatically via GitHub Actions.

🌐 Live Demo

πŸ‘‰ sajjadtalks.github.io/blog


πŸ“‚ Project Structure

πŸ“¦ your-blog-repo/ β”œβ”€ .github/workflows/build-site.yml # GitHub Actions workflow β”œβ”€ README.md # This file β”œβ”€ blog/ # Your markdown posts β”‚ β”œβ”€ Hello-World.md β”‚ └─ Python-Markdown.md β”œβ”€ generate.py # Blog generator script β”œβ”€ requirements.txt # Python dependencies β”œβ”€ static/ # Static assets (JS, CSS) β”‚ β”œβ”€ script.js β”‚ └─ style.css β”œβ”€ templates/ # HTML templates β”‚ β”œβ”€ base.html β”‚ β”œβ”€ index.html β”‚ └─ post.html └─ docs/ # Output folder (auto-generated) 

πŸ› οΈ Setup & Usage

1. Clone the repository

git clone https://github.com/sajjadtalks/blog.git cd blog

2. Create your blog posts

Put your Markdown files inside the blog/ folder. Example:

--- title: Hello World date: 2024-01-01 11:20:00 summary: This is my first post! --- # Welcome to My Blog This is the content of my first blog post.

Each post supports YAML frontmatter with fields like title, date, and summary.

3. Install dependencies

Use Python 3.11+ and run:

pip install -r requirements.txt

4. Build the site

python generate.py

The generated HTML site will be saved in the docs/ folder.

5. Preview locally (optional)

You can serve the site locally to preview it:

cd docs python -m http.server

Open http://localhost:8000 in your browser.


πŸš€ Auto Deploy with GitHub Actions

This project uses a GitHub Actions workflow to automatically build and deploy your blog to the gh-pages branch whenever you:

  • Push to the main branch
  • Modify any file in blog/, templates/, static/, generate.py, requirements.txt, or the workflow file itself

How it works:

  1. On Push: The GitHub Action runs generate.py to build the site into docs/
  2. Deploy: Uses peaceiris/actions-gh-pages to push the built site to gh-pages
  3. GitHub Pages: Serves your static site from the gh-pages branch

GitHub Pages Settings

Make sure to:

  1. Go to your repo’s Settings β†’ Pages
  2. Set:
    • Source: gh-pages branch
    • Folder: / (root)

πŸ” Features

  • πŸ—‚ Supports pagination (10 posts per page)
  • πŸ“… Sorts posts by date (newest first)
  • 🧠 Builds a search_index.json file for custom search
  • 🎨 Styled with custom style.css and supports codehilite
  • βœ… Automatically creates .nojekyll for proper GitHub Pages support
  • πŸ“„ Supports Markdown extensions like tables, task lists, code blocks

βœ… Requirements

  • Python 3.11+
  • See requirements.txt for packages like:
    • markdown
    • jinja2
    • python-frontmatter
    • pymdown-extensions

πŸ’‘ Example Post Format

--- title: My First Blog Post date: 2025-04-15 11:20:00 summary: This post talks about Python static site generators. --- # Hello Static Blogging! Here is **some content** with `code`. ``` python print("Hello World")``` 

πŸ“¦ Deployment Notes

You do not need to manually push to gh-pages. Just push your Markdown or template changes to main, and the deployment is automatic πŸš€


πŸ§ͺ License

MIT License β€” Free to use and modify.


πŸ™Œ Credits

Created with ❀️ by @sajjadtalks

Contributors 2

  •  
  •