DEV Community

Frank Corso
Frank Corso

Posted on • Updated on • Originally published at

Setting Up Pelican Static Site Generator

This was originally published over on

I have been hearing about static site generators for a while but haven't really had a use for one yet. So, when I decided to start my new site, I knew I wanted to try one out.

However, I quickly realized there are a dozen good ones and then countless others beyond those. Most of my recent development experience has been with Python and Vue, so I was able to narrow it down to either ones that use Python or ones that use JavaScript.

From there, since I have no experience with React, I narrowed down further to VuePress on the JavaScript side or Pelican or Nikola on the Python side. After experimenting with each of them, I decided to go with Pelican for now.

What is Pelican?

Pelican is a static-site generator that has been around since 2010 and allows one to create content in Markdown or reStructuredText. It is written in Python and utilizes Jinja templates for parsing and creating the final HTML pages.

Setting Up a Pelican Site

To get started with Pelican, you will need to ensure that it is installed locally. Since I preferred creating content within Markdown, Pelican recommended this command:

pip install pelican[Markdown]

From there, you can go to the directory you are setting up in and use this command to get a skeleton site set up:


This command will trigger a series of questions in the terminal to set up your site. For now, you can keep most of the defaults.

Terminal showing several questions asked by Pelican

Once you have finished answering the questions, you will see two new folders and two files.

Directory showing two folders of content and output

The content directory is where you will create your posts and pages. The output directory is where the site will be generated to.

The and files are where you can customize the settings and values Pelican uses to create your site. Most of the settings will be in the file. For example, within, you will be able to edit the values you entered during the quickstart.

The imports the settings from and can overwrite some settings as well as set new settings. This way, you can use for development and for production. For example, you may disable feed generation in to speed up development builds and then have them enabled in

Pelican's settings file

Before you can see your new site, you need to create your first article. Go into the content directory and create a Markdown file. I'll call mine

Inside your content Markdown files, you will use a series of key and value pairs in the header to set up your content. Underneath, you will add your content.

Title: My first post
Date: 2020-06-01 10:20
Category: Python
Tags: blog, tutorial
Slug: my-first-post
Authors: Frank Corso
Summary: Check out my first post!

This is some super awesome content within my post!
Enter fullscreen mode Exit fullscreen mode

In addition to this first post, we can create our first page. By default, Pelican will look for the pages directory inside content for any pages and automatically add them to the site's main navigation. I'll create an file to set up a basic about page.

Title: About Me
Date: 2020-05-27 10:20
Slug: about
Authors: Frank Corso

Hey there! My name is Frank Corso and it's nice to meet you.
Enter fullscreen mode Exit fullscreen mode

Once you have your Markdown files created, let's use pelican content to generate our content. By default, Pelican will use the built-in "simple" theme to generate your content and then place the HTML files into the output directory.

The new HTML files are now within the output folder

Once our content is created, we can use pelican --listen to set up a simple server so we can see our new content. By default, this will be at http://localhost:8000/.

Example site created by Pelican showing heading and first post

When you go to publish the site, if you are using the (or another file) for production settings, you would use pelican content -s to use that file's settings.

Next Steps

You now have your basic site! You can now add more articles and more pages. The next big step will be to research either downloading or creating a theme. I found a Pelican Themes site which displays screenshots for a lot of pelican themes and links to GitHub repositories.

Alternatively, you can create your own following the Pelican documentation.

Once you have theme files ready, you can add THEME = 'THEMEDIRECTORY' to the file to use your new theme instead of the default theme.

Now, get creating!

Top comments (4)

mintii profile image
Brittney Braxton

I think something that's crucial to point out is answering yes to the question of creating a Makefile while doing pelican quickstart. This was needed for ease in deploying. Thanks for sharing your experience. It greatly helped in making my test blog with Pelican!

fpcorso profile image
Frank Corso • Edited

I'm glad it helped!

Since make isn't something that is available on most Windows environments, like the one I use 😉, I was showing the command pelican --listen which will work across all platforms instead of make serve and would use pelican content instead of make html or make publish as shown in the top section of the "Publish your site" docs:

However, I agree that I should probably add some information about the Makefile and explain how to use it. I'll update the article this week when I have a moment.

mintii profile image
Brittney Braxton

Excellent point, and I'm sorry for assuming Make was available ubiquitously. How did you deploy your Pelican app? I was struggling with getting it launched on Netlify, and the makefile really helped.

Thread Thread
fpcorso profile image
Frank Corso

What I did with my site was use Netlify's GitHub integration to automatically build any time I push to my repo. Then, under the "Build & deploy" settings for the site, I use the pelican content build command and point the publish directory to output.

There are several steps to setting up Netlify, so I might write a follow-up post on this at some point but setting the build command and publish directory is the main part of getting it to work.