This article is the field reference for CSV imports in The Events Calendar. It covers every supported column for events, venues, organizers, virtual events, RSVPs, tickets, and ECP additional fields — along with downloadable example files you can use as a starting point.

For step-by-step instructions on running the import, see Importing Events from a CSV File.

Each column in a CSV file corresponds to a field that would be filled in manually when creating an event, organizer, venue, ticket, or RSVP in the WordPress editor. If a column name doesn’t match a recognized field, it won’t be included in the import. The field names and example data below are the recommended column headings to use in your files.

💡 Use YYYY-MM-DD for all dates. Some date formats are ambiguous — for example, 05/06/2016 could be read as May 6th or June 5th depending on locale. The ISO format YYYY-MM-DD is always unambiguous. If you need to use the day-first international format, use hyphens rather than slashes (e.g. 05-06-2016).

CSV Fields

Venues

Field NameExample DataField TypeNotes
Venue NamePrecious LambString
Venue DescriptionA non-profit preschool.HTML
Venue CountryUnited StatesStringPreferably the full country name.
Venue Address2005 Palo Verde AveString
Venue Address 2StringAppended to Venue Address on import.
Venue CityLong BeachString
Venue State/ProvinceCAString
Venue Zip90815String
Venue Overwrite1StringWhether geo-coordinates should determine venue location (Pro only). 0 = No (default), 1 = Yes.
Venue Latitude33.7924082String
Venue Longitude-118.1105883String
Venue Phone+1-800-123-4567Phone Number
Venue Websitehttp://www.example.com/URL
Venue Featured Imagehttp://www.example.com/image.pngURLMust be a direct URL to the image file.

Organizers

Field NameExample DataField TypeNotes
Organizer NameGeorge-Michael BluthString
Organizer DescriptionRecently started growing a moustache.HTML
Organizer Email[email protected]Email Address
Organizer Websitehttp://fakeblock.comURL
Organizer Phone+1-987-555-1238Phone Number
Organizer Featured Imagehttp://example.com/photo.jpgURLMust be a direct URL to the image file.

Events

Import or create your Venues and Organizers before importing Events. The event importer matches venues and organizers by exact name, so those records must already exist for the association to be made.

Field NameExample DataField TypeNotes
Event NameTurtleneck FittingString
Event DescriptionI <em>didn’t</em> invent the turtleneck, but…HTML
Event ExcerptI’m afraid of any apex predator…HTMLUsed as the excerpt; the Description field is the full content.
Event Start Date1965-12-31DateYYYY-MM-DD recommended. Example: December 31st, 1965.
Event Start Time21:30:00TimeTime the event starts. Example: 9:30 pm.
Event End Date1966-01-01DateYYYY-MM-DD recommended. Example: January 1st, 1966.
Event End Time00:50:00TimeTime the event ends. Example: 12:50 am.
All Day EventFALSEBooleanWhen true, the event lasts all day and Start/End Time fields are ignored.
TimezoneAmerica/New_YorkStringMust be a valid timezone string. See PHP timezone list.
Hide from Event ListingsFALSEBooleanWhen true, the event appears in Month View but not in list-style views.
Sticky in Month ViewTRUEBooleanWhen true, the event appears at the top of its day cell in Month View regardless of start time.
Event Venue NameArcher’s PenthouseComma SeparatedMust exactly match the Venue Name of an existing venue. By default only one venue per event is supported — see note below.
Event OrganizersWoodhouse, Chelsea S., 42Comma SeparatedMust exactly match the Organizer Name, or use the organizer’s post ID. Separate multiple values with commas.
Event Show Map LinkTRUEBoolean
Event Show MapTRUEBoolean
Event Cost500StringUse 0 for free events. Leave blank to hide the cost field. Unused when a ticketing plugin is active.
Event Currency Symbol$StringUnused when a ticketing plugin is active.
Event Currency PositionprefixUniqueAccepts prefix or suffix. Defaults to prefix. Unused when a ticketing plugin is active.
Event ISO Currency CodeUSD, EURStringAdds the ISO currency code alongside the event cost.
Event CategoryTacktleneck, TailorComma SeparatedSeparate multiple categories with commas.
Event TagsValet, Mission ready, PPKComma SeparatedSeparate multiple tags with commas.
Event Websitehttp://example.comURL
Event Featured Imagehttp://example.com/image.pngURLMust be a direct URL to the image file.
Allow CommentsTRUEBoolean
Allow Trackbacks and PingbacksFALSEBoolean

💡 While comma-separated values are technically supported in the Venue Name field, by default each event can only be assigned one venue. Specifying multiple venues only has an effect if multiple venue support has been enabled. In general, specify a single venue name here.

Virtual Events

With Events Calendar Pro installed, the following additional fields are available for virtual and hybrid events.

Field NameExample DataField Type
Configure Virtual Event?TRUEBoolean
Type of Event (Virtual, Hybrid)VirtualString
Video Source URLhttps://www.youtube.com/watch?v=2HMV0JhnB8kURL
Embed Video?TRUEBoolean
Linked Button TextButtonString
Linked ButtonTRUEBoolean
Show Embed atat-startString
Show Virtual Event Icon on Single?TRUEBoolean
Show Virtual Event on all ViewsTrueBoolean
Show Embed ToAllString
Include Link in RSVP Email?TRUEBoolean
Include Link in Ticket Email?TRUEBoolean

RSVPs

Import RSVPs after importing the events they belong to, since RSVPs must be associated with existing events.

Field NameExample DataField TypeNotes
Event Name, ID, or SlugNYPL Author Series: Shane PearlmanString
Ticket NameGeneral SeatingString
Ticket DescriptionReservation for a seat in the Peifer Auditorium.HTML
Ticket Start Sale Date2016-12-01DateYYYY-MM-DD recommended.
Ticket Start Sale Time14:30:00Time
Ticket End Sale Date2016-12-15DateYYYY-MM-DD recommended.
Ticket End Sale Time21:30:00Time
Ticket Stock450IntegerCSV only accepts integers for ticket stock.
Ticket Show DescriptionYes|NoString

WooCommerce Tickets

Import tickets after importing the events they belong to. Note that only WooCommerce Tickets can be imported via CSV.

The import type dropdown showing the Tickets option, which only appears when WooCommerce is active
Field NameExample DataField TypeNotes
Event Name, ID, or SlugNYPL Author Series: Shane PearlmanString
Ticket NameGeneral SeatingString
Ticket DescriptionTicket for a seat in the Peifer Auditorium.HTML
Ticket Start Sale Date2016-12-01DateYYYY-MM-DD recommended.
Ticket Start Sale Time14:30:00Time
Ticket End Sale Date2016-12-15DateYYYY-MM-DD recommended.
Ticket End Sale Time21:30:00Time
Ticket Price$25.00StringAn integer without the currency symbol is also acceptable.
Ticket Stock450IntegerCSV only accepts integers for ticket stock.
Ticket SKUGEN-ADString

A separate example CSV file for WooCommerce Tickets is not available. Use the RSVP example file as a base and add the Ticket Price and/or Ticket SKU columns as needed. When running the import, select Tickets (not RSVPs) from the content type dropdown. Make sure the Event Name field in your ticket CSV matches the Event Name in your events CSV exactly, or no tickets will be imported.

Additional Fields

If you have Events Calendar Pro and have created custom additional fields, those fields will appear in the CSV importer as available columns to map. The column name to use in your CSV is the label you gave the field when you created it. The following table shows which field types are supported by the importer:

Field TypeExample DataNotes
Text FieldI swear I had something for this.String
Text Area FieldDo you want ants? …because that’s how you get ants.String
URL Fieldhttp://www.example.com/URL
Radio FieldRead a bookMust be an exact case-sensitive match to an existing option name.
Checkboxes FieldBoop|YupSeparate multiple selected options with a pipe | character.
Dropdown FieldDanger Zone!Must be an exact case-sensitive match to an existing option name.

Field Type Glossary

The field type column in each table above uses the following definitions:

  • HTML — Accepts HTML markup. Also runs through wpautop(), so two consecutive newlines are interpreted as a paragraph break, just as in the WordPress editor.
  • String — Accepts most text including numbers and special characters. Newlines are typically ignored.
  • Boolean — Accepts true/false, 1/0, or yes/no. Not case-sensitive. When left blank the default is applied, which is typically false.
  • Integer — Accepts whole numbers only.
  • Date — Accepts formatted dates. Use ISO 8601 YYYY-MM-DD (e.g. 2025-12-31) for unambiguous results. For the North American MM/DD/YYYY format use slashes. For the international DD-MM-YYYY format use hyphens.
  • Time — Accepts formatted times in ISO 8601 HH:MM:SS format (e.g. 23:59:59).
  • URL — Accepts full URLs including the protocol (e.g. https://).
  • Comma Separated — Accepts a comma-separated list of values. “Concert, Barbecue” is interpreted as two separate values: “Concert” and “Barbecue”. If you’re not exporting from Excel or a similar tool, make sure to properly escape fields containing commas so they aren’t treated as column separators.
  • Email Address — Accepts any string, but prefers a valid email address format.
  • Phone Number — For proper internationalization, include the full number with country code and leading + (e.g. +1-800-867-5309).

Adding Custom Columns to CSV Imports

If you have custom data that isn’t covered by the built-in fields — for example, post meta stored by another plugin, or your own custom meta keys — you can add those columns to the importer using the following snippet.

Define your custom fields in the $custom_import_data array: the array key is the meta key that will be saved to the database, and the value is the label that will appear in the importer’s column mapping dropdown. The snippet handles registration, processing, and saving automatically.

class TEC_CSV_Import_Custom_Metadata {
    /**
     * Define your custom data here.
     * key   => the meta key that will be used to save the data
     * value => the label shown in the column mapping dropdown
     *
     * @var string[]
     */
    public $custom_import_data = [
        '_tribe_events_status' => 'Event Status',
        'meta_key_1'           => 'Meta Data 1',
        'meta_key_2'           => 'Meta Data 2',
    ];

    public function __construct() {
        add_filter( 'tribe_events_importer_event_column_names', [ $this, 'add_column_name' ] );
        add_filter( 'tribe_events_csv_import_event_additional_fields', [ $this, 'process_custom_data' ] );
        add_action( 'tribe_events_update_meta', [ $this, 'save_custom_data' ], 10, 3 );
    }

    public function add_column_name( $column_names ) {
        foreach ( $this->custom_import_data as $key => $value ) {
            $column_names[ $key ] = $value;
        }
        return $column_names;
    }

    public function process_custom_data() {
        $extra_fields['tec_import_event_status'] = 'tec_import_event_status';
        foreach ( $this->custom_import_data as $key => $value ) {
            $extra_fields[ $key ] = $key;
        }
        return $extra_fields;
    }

    public function save_custom_data( $event_id, $data, $event ) {
        foreach ( $this->custom_import_data as $key => $value ) {
            if ( isset( $data[ $key ] ) &amp;&amp; $data[ $key ] != '' ) {
                update_post_meta( $event_id, $key, esc_html( $data[ $key ] ) );
            }
        }
    }
}

new TEC_CSV_Import_Custom_Metadata();

Add this to your child theme’s functions.php file or via the Code Snippets plugin.

The _tribe_events_status key in the example above maps to TEC’s built-in event status field, which supports three statuses out of the box (also defined by schema.org):

  • Scheduled (default)
  • Canceled
  • Postponed

To define your own custom event statuses, see Adding a Custom Event Status.