This is a fork of the original Exitwp, mantained by Marco Frisan, that brings a widely refactored code with the following capapilities.
- Support for Python 3
- More cecks and stability
- Support for images download (borrowed from Exitwp3)
- It doesn't quit anymore if it fails to download an image
Exitwp is tool for making migration from one or more wordpress blogs to the jekyll blog engine as easy as possible.
By default it will try to convert as much information as possible from wordpress but can also be told to filter the amount of data it converts.
The latest version of these docs should always be available at https://github.com/thomasf/exitwp
- Download or clone using
git clone https://github.com/thomasf/exitwp.git
- Export one or more wordpress blogs using the wordpress exporter under tools/export in wordpress admin.
- Put all wordpress xml files in the
wordpress-xml
directory - Special note for Wordpress 3.1, you need to add a missing namespace in rss tag :
xmlns:atom="http://www.w3.org/2005/Atom"
- Run xmllint on your export file and fix errors if there are.
- Run the converter by typing
python exitwp.py
in the console from the directory of the unzipped archive - You should now have all the blogs converted into separate directories under the
build
directory
- Python 3.9.7 (it could work also with previous minor versions but I never tested it)
- html2text : converts HTML to markdown (python)
- PyYAML : Reading configuration files and writing YAML headers (python)
- Beautiful soup : Parsing and downloading of post images/attachments (python)
sudo apt-get install python-yaml python-bs4 python-html2text
From the checked out root for this project, type:
sudo pip install --upgrade -r pip_requirements.txt
Note that PyYAML will require other packages to compile correctly under ubuntu/debian, these are installed by typing:
sudo apt-get install libyaml-dev python-dev build-essential
In the event your local system is incompatible with the dependencies listed (or you'd rather not install them), you can use the included Vagrantfile to start a VM with all necessary dependencies installed.
- Lint and place all wordpress xml files in the
wordpress-xml
directory as mentioned above - In the directory of the unzipped archive, run
vagrant up
. - SSH to your Vagrant VM using
vagrant ssh
- Run
cd /vagrant
to open the VM's shared folder - Run the converter from the VM by typing
python exitwp.py
- After the converter completes, exit the SSH session using
exit
- You should now have all the blogs converted into separate directories under the
build
directory - Important: Once satisfied with the results, run
vagrant destroy -f
to shut down the VM and remove the virtual drive from your local machine
See the configuration file for all configurable options.
Some things like custom handling of non standard post types is not fully configurable through the config file. You might have to modify the source code to add custom parsing behaviour.
- Target file names are some times less than optimal.
- Rewriting of image/attachment links if they are downloaded would be a good feature
- There will probably be issues when migrating non utf-8 encoded wordpress dump files (if they exist).
- A Gist to convert WP-Footnotes style footnotes to PHP Markdown Extra style footnotes: https://gist.github.com/1246047