Gravity Forms Entries in Excel


Export all entries from your forms directly to Excel, using a unique and secure url. No need to login, or create a
user account for that one person who needs te results. Just copy the url, and give it to the guy who needs it.
It’s that simple.

Using Gravity Forms you can export a CSV file, and import it to Excel. But an admin always needs to be involved
and using Excel to import a CSV is a pain in the butt.

The plugin has a lot of event-hooks to make your Excel output exactly how you want it.
Check out the FAQ to find out more.


I’ve added a documentation website. This docs will be updated from time to time with new features, fields and filters.
I’m planning to add recipes for quick updates, based on your questions. So if you have a specific need; Ask away!
If you are a developer; this site is probably for you.

Please visit:


Want to help out the development of the plugin, or just buy me a drink 🍺? You can make a donation via my paypal page: But as always; no pressure.


  • PHP 7.1. (No longer active support for 5.6)
  • php-xml and php-zip libraries. The plugin will check for those.
  • Gravity Forms 2.0.0 or higher



  • A 'Entries in Excel' link is added to the form settings
  • There is your url! Just copy and paste to the browser (or click the download button)
  • Or download it from the list via the bulk selector


This section describes how to install the plugin and get it working.

  1. Upload gf-entries-in-excel to the /wp-content/plugins/ directory
  2. Activate the plugin through the ‘Plugins’ menu in WordPress
  3. Go to Forms > Select a form > Settings > Results in Excel to obtain your url
  4. Download that Excel file!


I don’t want the the metadata like ID, date, and IP in my file

No problem. You can use the gfexcel_output_meta_info or gfexcel_output_meta_info_{form_id} hooks to disable
this feature. Or (since version 1.4.0) you can select individual fields you want to exclude on the settings page.

Just add this to your functions.php:

I want to rename the labels, but only in Excel, how can I do this?

Sure, makes sense. You can override the label hooking into
gfexcel_field_label, gfexcel_field_label_{type}, gfexcel_field_label_{type}_{form_id} or

The field object is provided as parameter, so you can check for type and stuff programatically.

How can I change the value of a field in Excel?

You can override the value by hooking into gfexcel_field_value, gfexcel_field_value_{type},
gfexcel_field_value_{type}_{form_id} or gfexcel_field_value_{type}_{form_id}_{field_id}

The entry array is provided as a parameter, so you can combine fields if you want.

Can I seperate the fields of an address into multiple columns?

Great question! Yes you can! You can set it on the setting spage, or make use of the following hooks to get that working:
gfexcel_field_separated_{type}{form_id}{field_id} where every variable is optional.

I have a custom field. Can your plugin handle this?

You should ask yourself, if your field can handle this plugin! But, yes it can. In multiple ways actually.

The default way the plugins renders the output, is by calling get_value_export on the field.
All Gravity Forms fields need that function, so make sure that is implemented.
The result is one column with the output combined to one cell per row.

But you can also make your own field-renderer, like this:

  1. Make a class that extends GFExcel\Field\BaseField (recommended) or extends GFExcel\Field\AbstractField or implements GFExcel\Field\FieldInterface
  2. Return your needed columns and cells by implementing getColumns and getCells. (See AddressField for some inspiration)
  3. Add your class via the gfexcel_transformer_fields hook as: type => Fully Qualified Classname (eg. $fields[‘awesome-type’] => ‘MyTheme\Field\MyAwsomeField’)
I don’t really like the downloaded file name!

By now you really should know you can change almost every aspect of this plugin. Don’t like the name? Change it using the settings page, or by using the gfexcel_renderer_filename or gfexcel_renderer_filename_{form_id} hooks.

Also you can update title, subject and description metadata of the document by using
gfexcel_renderer_title({form_id}), gfexcel_renderer_subject(_{form_id}) and

Can I change the sort order of the rows?

Sure, why not. By default we sort on date of entry in acending order. You can change this, per form,
on the Form settings page (Results in Excel) under “Settings”.

I want to download directly from the forms table without the url!

Allright! No need to yell! For those situation we’ve added a bulk option on the forms table.
As a bonus, you can select multiple forms, and it will download all results in one file,
on multiple worksheets (oohhh yeah!)

How can I disable the hyperlinks on URL-only cells?

You can disable the hyperlinks by using the gfexcel_renderer_disable_hyperlinks-hook.

//add this to your functions.php
My numbers are formatted as a string, how can I change the celltype?

A numberfield is formatted as a number, but most fields default to a string.
As of this moment, there are 3 field types. Boolean,String and Numeric. You can set these per field.

//add this to your functions.php
use GFExcel\Values\BaseValue;

add_filter('gfexcel_value_type',function($type, $field) {
    if($field->formId == 1 && $field->id == 2) {
        //Possible values are 'bool', 'string' or 'numeric',
        //or, use the constant, preffered:
        return BaseValue::TYPE_NUMERIC; //TYPE_STRING, TYPE_BOOL
}, 10, 2);
I’d like to add a hyperlink to a specific field

Since most values are Value Objects, we can interact with them, and trigger a setUrl function on a value.

//add this to your functions.php
add_filter('gfexcel_value_object',function($value, $field) {
    if($field->formId == 1 && $field->id == 2) {
}, 10, 2);
I’ve added some notes, where are they?

By default the notes are disabled for performance. If you’d like to add these to the row you can activate this like so:

//add this to your functions.php
add_filter('gfexcel_field_notes_enabled_{formid}','__return_true'); // eg. gfexcel_field_notes_enabled_2
It’s all to boring in Excel. Can I use some colors?

Definitely! You get to change: text color, background color, bold and italic. If that is not enough, you probably just need to add those Clip Arts yourself!

//add this to your functions.php
add_filter('gfexcel_value_object', function (BaseValue $value, $field, $is_label) {
    // Need to know if this field is a label?
    if (!$is_label) {
        return $value;

    $value->setColor('#ffffff'); //font color, needs a six character color hexcode. #fff won't cut it here.
    $value->setBold(true); // Bold text
    $value->setItalic(true); // Italic text (to be combined with bold)
    $value->setBackgroundColor('#0085BA'); // background color

    // $field is the GF_Field object, so you can use that too for some checks.
    return $value;
}, 10, 3);
I don’t have enough… eh… Memory!

Yes, this can happen. And to be frank (actually, I’m not, I’m Doeke), this isn’t something that can be fixed.
As a default, WordPress allocates 40 MB of memory. Because the plugin starts the rendering pretty early, it has most of it available.
But every cell to be rendered (even if it’s empty) takes up about 1KB of memory. This means that you have (roughly)
40 MB * 1024 KB = 40.960 Cells. I say roughly, because we also use some memory for calculations and retrieving the data.
If you’re around this cell-count, and the renderer fails; try to upgrade the WP_MEMORY_LIMIT. Checkout Woocommerce’s Docs for some tips.

Can I hide a row, but not remove it?

You got something to hide, eh? We got you “covered”. You can hide a row by adding a hook. Why a hook and not a nice GUI? Because everyone has different reasons for hiding stuff. So I couldn’t come up with a better solution for now.
Checkout this example:

add_filter('gfexcel_renderer_hide_row', function ($hide, $row) {
     foreach ($row as $column) {
         if ($column->getFieldId() === 1 && empty($column->getValue())) {
             return true; // hide rows with an empty field 1
     return $hide; // don't forget me!
 }, 10, 2);


This plugin has the perfect set of options for what it sets out to do, and it naturally integrates into Gravity Forms as it should. Thanks for your work on this!
Hi! Support responded very quickly, within 10 minutes. It is wonderful! Together we found a quick solution to the problem and now there is a fix. Now this plugin is the only free working solution for exporting forms!


Gravity Forms Entries in Excel はオープンソースソフトウェアです。以下の人々がこのプラグインに貢献しています。


“Gravity Forms Entries in Excel” は1ロケールに翻訳されています。 翻訳者のみなさん、翻訳へのご協力ありがとうございます。

“Gravity Forms Entries in Excel” をあなたの言語に翻訳しましょう。

開発に興味がありますか ?

コードを閲覧するか、SVN リポジトリをチェックするか、開発ログRSS で購読してみてください。



  • Bugfix: Radio and checkboxes caused unforseen error on shorttag for GF.


  • Bugfix: Referenced unavailble contstant.
  • Bugfix: short code had an breaking edge case.


  • Security: Removed old style URL. If you were using it, please regenate the URL.
  • Enhancement: Added [gfexcel_download_link id=2] shorttag for WordPress and {gfexcel_download_link} for GF notification.
  • Enhancement: Added reset of download counter (also refactored all couter code to SRP class).
  • Enhancement: Added setting to format prices as numeric values.
  • Enhancement: Added a download event so you can append logic to the download moment.
  • Enhancement: Added CreatedBy field to easily change user_id to nickname or display_name. Use filter gfexcel_meta_created_by_property.
  • Bugfix: Stripping title could cut multibyte character in half, making the xlsx useless.
  • Bugfix: Removed start_date or end_date from date range filter when empty. Caused errors for some.
  • Bugfix: created_by and payment_date were not converted to the wordpress timezone.


  • Feature: The renderer now supports transposing. So every column is a row, and vica versa.
  • Feature: Added a date range filter. Also included as start_date and end_date query_parameters.
  • Feature: Added a “download” link per form on the Forms page. Less clicks for that file!
  • Feature: Hide a row by hooking into gfexcel_renderer_hide_row. Checkout the FAQ for more info.
  • Enhancement: All separable fields are handled as such, except for checkboxes. Made no sense.
  • Enhancement: Product and calculation have some specific rendering on single field for clearity.
  • Enhancement: Now supports Gravity Forms Chained Selects.
  • Enhancement: Quering entries in smaller sets to avoid massive database queries that can choke a database server.
  • Enhancement: Added a gfexcel_output_search_criteria filter to customize the search_criteria for requests.
  • Bugfix: Downloading files didn’t work on iOS.
  • Info: PHP 5.6 is no longer actively supported. Will probably still work; but 7.1 is the new minimum.
  • Info: Launched a (first version) documentation site! Checkout


  • Enhancement: Date fields now export the date according to it’s field setting.
  • Enhancement: Value Objects (BaseValue) can reference getField(), getFieldType() and getFieldId() to help with filtering.
  • Enhancement: Name fields can now also be split up in to multiple fields. Made this a generic setting on the settings page. Please re-save your settings!
  • Enhancement: Subfield labels can now also be overwritten with the gfexcel_field_value-hook.
  • Bugfix: Found a memory leakage in retrieving fields for every row. Will now be retrieved only once per file.
  • Bugfix: Custom Sub field labels were not exported.
  • Bugfix: I spelled ‘separate’ wrong, and therefor the hooks were also wrong. Please update your hooks If you use them!


  • Language: Finnish language files added thanks to @Nomafin!
  • Enhancement: Better inclusion of script and styles.
  • Enhancement: Renamed Results in Excel to Entries in Excel to be more consistent.
  • Enhancement: Added a quick link to settings from the plugins page.
  • Bugfix: Wrong minimum version of Gravity Forms set, should be 2.0.
  • Help: Added some help text to the global settings page. I need your input!


  • Enhancement: Added plugin settings page with plugin wide default settings
  • Enhancement: Added dependency checks to plugin, so without them, the plugin won’t work.
  • Bugfix: Prices were shown in html characters. Not really a bug, but it was bugging someone 🙂
  • Bugfix: Address field needed wrapping of value objects on separate fields.
  • Bugfix: Some fields were missing wrapping of value object.


  • Bugfix: Posting a form gave a 500 error, because of missing form info in front-end.


  • (Awesome) Feature: You can now set the order of the fields by sorting them, using drag and drop!
  • Feature: Add colors and font styles to cells by using the gfexcel_value_object-hook (See docs).
  • Feature: Attach a single entry file to a notification email.
  • Feature: We now support exports in CSV. Why? Because we can! (and also Harry asked me too).
  • Enhancement: You can now add .xlsx or .csv to the end of the URL, to force that output.
  • Enhancement: Added support for the Woocommerce add-on.
  • Enhancement: Added support for the Members plugin. You need ‘gravityforms_export_entries’ role for this plugin.
  • Bugfix: The extension did not match the renderer, which sometimes caused Excel to give a warning.
  • Bugfix: Lists with a single column could not be exported.


  • Failed upload. I wish WordPress would drop the ancient SVN approach!


  • Celebration: 1000+ active installations! Whoop! That is so awesome! Thank you for the support and feedback!
    As a celebration gift I’ve added some new settings, making the plugin more user-friendly, while maintaining developer-friendliness!
  • Feature / Security: Regenerate url for a form, with fallback to old way. But please update all your urls!
    This update also makes the slug more secure and unique by not using the (possibly default) NONCE_SALT.
  • Feature: Disable fields and metadata with checkboxes on the settings page. Can still be overwritten with the hooks.
  • Feature: Enable notes on the settings page. Can still be overwritten with the hook.
  • Feature: Added setting to set the custom filename. Can also still be overwritten with the hook.
  • Feature: Added error handling to provide better feedback and support.


  • Enhancement: Added notes per entry. Activate with gfexcel_field_notes_enabled.
  • Enhancement: Removed unneccecary files from the plugin to make it smaller.


  • Feature: Wrapped values in value objects, so we can be more specific in Excel for cell-type-hinting
  • Feature: NumberField added that uses the NumberValue type for Excel
  • Feature: Added filters to typehint cell values. See FAQ for more info.
  • Enhancement: updated cell > url implemntation. Each cell can be set individually now. See FAQ for more info.
  • Upgraded to PHP 5.6 for minimal dependancy. Last version with PHP 5.3 was 1.2.3
    (sorry for the mixup, the new renderer forced my hand, and I forgot about this, otherwise the verisoning had gone up sooner.)


  • Enhancement: moved away from deprecated PhpExcel to PhpSpreadsheet (Thanks @ravloony).
  • Enhancement: composer.json update to wordpress-plugin for easier installation with bedrock.
  • Enhancement: Metadata now uses GFExport to get all metadata; so a row now has all metadata. Can still be disabled.
  • Feature: New ListField transformer. Splits list fields into it’s own excel columns, with newline-seperated values per column.
  • Feature: New meta fields transformer. Special filter hooks for meta fields with gfexcel_meta_value.
  • Feature: New meta subfield transformer for date_created. Use gfexcel_meta_date_created_seperated to split date and time in 2 columns.
  • Bugfix: Plugin hooks later, so filters also work on bulk-download files.


  • Bugfix: Worksheets could contain invalid characters, and break download.
  • Last version to use PHP 5.3


  • Enhancement: If a cell only contains a URL, that URL is set as a link on that cell, for easy access.


  • Translation: Added Dutch translation + enabled posibility to translate via You can help me out!
  • Enhancement: Worksheets now have a title, and of course a gfexcel_renderer_worksheet_title hook.


  • (Very cool) Feature: Download Excel output directly from forms table, and (drumroll), download multiple forms in one file!
  • Feature: Added gfexcel_field_disable filter to disable all fields you want. Fields will be filtered out before handling.
  • Feature: Added gfexcel_output_rows and gfexcel_output_columns filters to have more control over output. Thanks @mircobabini.
  • Feature: Added a setting for sort order per form. Also contains some hooks to override that work!


  • Feature: Download counter (starts counting as of this version)
  • Feature: SectionField added to disable empty section columns. Disabled by default. Enable with gfexcel_field_section_enabled hook (return true).
  • Feature: FileUploadField added to disable file upload columns. Enabled by default. Dnable with gfexcel_field_fileuploads_enabled hook (return false).
  • Update: Wait until plugins are loaded. Need to be sure Gravity Forms is active. This caused a problem in some multisite implementations.
  • Bugfix: Changed the permalink registration so it works with multisite combined with the GF API (thanks for the assist @zitomerh). No need to reactivate the plugin now.
  • Bugfix: In Standard URL permalink structure, the hash wasn’t escaped properly


  • Bugfix: Only 20 results were beging returned by the GFAPI
  • The title of a form could not be longer than 31 characters


  • Updated readme
  • Removed unnecessary assets


  • First release