This tool will help you use the official Flickr account export to generate files that can then be imported into WordPress.
This is not a "one click" solution. It requires some manual configuration and general comfort with working on the command line. It may not work for your particular Flickr account or WordPress setup without some changes. It may not work at all.
I designed this tool to facilitate this basic approach:
- Download all photo files and metadata from Flickr.
- Use the downloaded information to construct a valid WXR import file and a valid WordPress
uploads
directory. - Move the
uploads
directory in to place and import the WXR file in to WordPress. - End up with a complete WordPress media library and set of posts, one for each Flickr image.
(The resulting site should have your photos, photo meta data, tags and comments. Some key meta values will also be archived in WordPress post meta for later use, e.g. if you want to find/replace references to Flickr URLs in content on another site to use your new WordPress URLs instead.)
This is probably not the best way to do this, but it was the right way for me.
Yes, there are an increasing number of tools that make use of the perfectly good Flickr API to access and download photos for use in other environments. In particular the Keyring Social Importers plugin is a pretty robust way to bring in existing and new Flickr content to WordPress via the Flickr API.
For this tool to be useful to you, you'll need:
- Access to your Flickr account, where you should initiate a request to make a full export of all your Flickr data available, and then download all of the resulting zip files for both the "Account Data" and for the "Photos and Videos".
- A Flickr API key (if you want to include commenter names in your WordPress site)
- A local command line environment with PHP installed, the jhead image manipulation tool, and enough disk space to work with an extracted archive of your Flickr photos, and possibly two copies of that data. I did all this on macOS. (You can get a good idea of how much space that is by going to "You -> Stats" on Flickr and seeing what it says you're using there.)
- A fresh install of WordPress where you have the ability to run WP CLI commands and to directly upload (probably via SFTP) and manipulate files on the local filesystem.
- A little patience, as there are a number of steps involved.
There are some known limitations with this tool:
- No support for migrating videos or other non-JPG files. Nothing technical preventing this, I just didn't bother yet. The script will output a list of files that need to be handled manually.
The jhead image manipulation tool is listed as a requirement because I could not find an easy way to get Flickr's interaction with image orientation data to reliably translate into WordPress's interaction with image orientation data. The end result was images that were rotated on their sides or upside down.
The easiest solution I could find was to do a one-time fix on the source image files themselves before beginning to import them in to WordPress.
If you're on a Mac and using Brew, setup should be as easy as brew install jhead
.
See instructions below for actual image rotation commands.
You may also wish to consider installing the Fix Image Rotation plugin or similar on your site for future photo uploads; there are still known issues with how rotated images shared from (for example) iOS devices are handled in WordPress.
-
Create a working directory for this effort somewhere in your local environment and
cd
to it. -
Clone this repo using
git clone git@github.com:ChrisHardie/flickr-to-wordpress.git
. -
Move your zip files downloaded from Flickr in to the working directory and extract them. Leave the photo file directories named as they are (e.g.
data-download-1
) but rename the directory containing the meta data (one JSON file per photo, among other things) to a sub-directory called justmeta
. -
Create a few more output sub-directories:
mkdir wxr uploads
; -
In the
config/
directory, copyexample-config.php
toconfig.php
and edit the file to fill in the variables defined there. -
So, now your directory structure should look something like:
/flickr-archive/ /config/config.php /generate-wordpress-import.php /README.md /meta/ photo_1234.json photo_5678.json ... /wxr/ /uploads/ /data-download-1/ image_1234.jpg image_4567.jpg /data-download-2/ image_8910.jpg ... ...
-
Do a one-time rotation of any images needing it. Find the highest numbered data directory containing image files, and then execute this shell command replacing 4 with that highest number:
for i in {1..4}; do jhead -autorot data-download-$i/*.jpg; done
. -
Run the import generation script:
php generate-wordpress-import.php
. -
Confirm that there is a WXR file in the
wxr/
output directory, and that there is a fully formeduploads/
folder with year and month sub-directories containing images.
If you run into issues with the size of the generated WXR, the script supports the --split
argument, which will output multiple smaller WXR files instead of one big one.
You should now have everything you need to populate your empty WordPress instance with your photos and metadata. Here are the steps I followed for that:
- Transfer the generated
uploads/
sub-directory into your WordPress instance'swp-content/
directory. I did this by runningtar -czvf photos-uploads.tgz uploads/
and then usingscp
to copy the tar file to my web server. Once it was there, I untarred it intowp-content
. - Transfer the generated
000-combined.wxr
file to a working directory somewhere accessible from the WordPress instance. - Install and activate the WordPress Importer plugin:
wp plugin install wordpress-importer --activate
- Temporarily patch the WordPress Importer plugin to prevent the remote fetch of images mentioned in the import file. I did this by applying an existing Pull Request that has not yet been merged into that plugin:
cd wp-content/plugins/wordpress-importer/ curl -LO https://github.com/WordPress/wordpress-importer/pull/39.patch patch < 39.patch rm 39.patch
- Enable the patch just applied by adding
define( 'IMPORT_PREVENT_REMOTE_FETCH', true );
to your wp-config.php file. - Temporarily disable the generation of multiple image sizes during import by adding
add_filter( 'intermediate_image_sizes_advanced', '__return_false' );
to your theme's functions.php file. This will make the initial import much faster. - Run the import, using something like
wp import 000-combined.wxr --authors=skip
. You may need to specify a different path to your WXR file depending on where you put it. You may wish to pipe the output to a file for later examination in case of problems. When the import finishes runwp cache flush
. - Test that the import was successful. Visit the posts list, tag list, media library and the site itself to confirm that everything works as expected. Note: the site will not yet have smaller image sizes generated, so things may load slowly until that part is done in the next step.
- Delete and reinstall the WordPress Importer plugin, and the related wp-config.php entry, if you want to remove the patched functionality.
- Remove the
add_filter( 'intermediate_image_sizes_advanced', '__return_false' );
line from your functions.php file. Generate other image sizes usingwp media regenerate --only-missing --yes
. This could take quite a while depending on how many images you have and the resources available on your web server.
That's it! You should now have a self-contained copy of your Flickr photos in WordPress!
Since I only tested this process on my own Flickr account, I'm 99% sure that it will fall apart in some way for other people. If you open an Issue with as many details as possible, I will do my best to offer thoughts on how to further improve this tool to help you. Better yet, if you find a way to make it more broadly useful, or even just to make this documentation more clear, please submit a Pull Request!
- Chris Hardie
- https://chrishardie.com/
- https://photos.chrishardie.com/