Sitecore Forms Export to Semicolon File

  • Twitter
  • LinkedIn

Sitecore Forms - Export to Semicolon File

The new dashboard for Sitecore Forms has a button that allows a user to export their form data to a CSV file. When clicking on that button, you can choose to export all data or a specific date range. Interestingly enough, when that CSV gets generated, it shows up with semi-colons as the delimiter. Under normal circumstances, this wouldn't be a big deal, except that the export provider forgot to tell the file that it uses a semi-colon as the delimiter. This results in the file not gracefully opening in Excel. This popped up in a question on Slack today, and I remembered that we applied a "fix" for this in a project. A colleague of mine, Keith Deshane, solved this problem by overwriting the controller used to generate the export. In going through his change, I did a deeper dive into the implementation, and was able to achieve a similar resolution with a little less code.

Out of the box, Sitecore leverages the Sitecore.ExperienceForms.Client.Data.CsvExportProvider class to generate the file content when the user chooses to export the form data. DotPeek (a Sitecore dev's best friend) told me that the semi-colon as the delimiter is hard-coded into the implementation:

This means that we can either write our own export provider, or figure out a way to tell the exported file that it is full of semi-colons. Luckily, the implementation of the provider uses virtual methods!! :D

Let's make a new class that extends the existing provider:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

public

class

SemiColonExportProvider : CsvExportProvider

{

public

SemiColonExportProvider(IFormDataProvider formDataProvider) : ``base``(formDataProvider) { }

protected

override

string

GenerateFileContent(IEnumerable formEntries)

{

// this will tell the file that it is using semi-colons

const

string

separator = ``"\"sep=;\"\r\n"``; /* see foot note */

var content = ``base``.GenerateFileContent(formEntries);

var stringBuilder = ``new

StringBuilder();

stringBuilder.AppendLine(separator);

stringBuilder.AppendLine(content);

return

stringBuilder.ToString();

}

}

This class is pretty straight forward. We extend the existing provider, and are going to use most of the logic. The first line of the GenerateFileContent method will tell the file that the separator is a semi-colon. We can leverage the default logic for loading up the content, and then just make sure the separator is added to the beginning of the file.

All that is left is to swap out the original provider with the new provider:

?

1

2

3

4

5

6

7

< />

xmlns:patch``=``"[http://www.sitecore.net/xmlconfig/](http://www.sitecore.net/xmlconfig/)"``>

<``sitecore``>

<``services``>

< />

serviceType``=``"Sitecore.ExperienceForms.Data.IExportDataProvider, Sitecore.ExperienceForms"

implementationType``=``"Feature.Forms.Providers.SemiColonExportProvider, Feature.Forms"

patch:instead``=``"*[@implementationType='Sitecore.ExperienceForms.Client.Data.CsvExportProvider, Sitecore.ExperienceForms.Client']"``/>




Easy as that, the new export logic will now generate a file that can be interpreted by Excel:

FOOTNOTE: @mike_i_reynolds says not to hard code string literals. Check out this post to learn how you can configure and inject the separator string.

I hope this helps alleviate some headache when it comes to figuring out why your exported form data isn't opening gracefully.

View more blogs and tutorials about Sitecore

Learn about our Sitecore work