Data Grid - Export
Export the rows in CSV or Excel formats, or use the browser's print dialog to print or save as PDF.
Enabling export
Default toolbar
To display the default export options, pass the showToolbar prop, as shown in the demo below.
Custom toolbar
See the Export component for examples of how to add export triggers to a custom toolbar.
Export options
Following are the available export options:
Where relevant, the options are automatically shown in the toolbar. You can customize their respective behavior by passing an options object either to slotsProps.toolbar or to the Export trigger itself if you have a custom toolbar:
// Default toolbar:
<DataGrid slotProps={{ toolbar: { csvOptions } }} />
// Custom trigger:
<ExportCsv options={csvOptions} />
Each export option has its own API page:
Remove export options
You can remove an export option from the toolbar by setting the disableToolbarButton property to true in its options object.
In the following example, the print export is disabled.
Exported columns
By default, the export will only contain the visible columns of the Data Grid. There are a few ways to include or hide other columns.
- Set the disableExportattribute totrueinGridColDeffor columns you don't want to be exported.
<DataGrid columns={[{ field: 'name', disableExport: true }, { field: 'brand' }]} />
- Set allColumnsin export option totrueto also include hidden columns. Those withdisableExport=truewill not be exported.
<DataGrid slotProps={{ toolbar: { csvOptions: { allColumns: true } } }} />
- Set the exact columns to be exported in the export option. Setting fieldsoverrides the other properties. Such that the exported columns are exactly those infieldsin the same order.
<DataGrid slotProps={{ toolbar: { csvOptions: { fields: ['name', 'brand'] } } }} />
Exported rows
By default, the Data Grid exports the selected rows if there are any. If not, it exports all rows except the footers (filtered and sorted rows, according to active rules), including the collapsed ones.
Customizing the rows to export
Alternatively, you can set the getRowsToExport function and export any rows you want, as in the following example.
The grid exports a few selectors that can help you get the rows for the most common use-cases:
| Selector | Behavior | 
|---|---|
| gridRowIdsSelector | The rows in their original order. | 
| gridSortedRowIdsSelector | The rows after applying the sorting rules. | 
| gridFilteredSortedRowIdsSelector | The rows after applying the sorting rules, and the filtering rules. | 
| gridExpandedSortedRowIdsSelector | The rows after applying the sorting rules, the filtering rules, and without the collapsed rows. | 
| gridPaginatedVisibleSortedGridRowIdsSelector | The rows after applying the sorting rules, the filtering rules, without the collapsed rows and only for the current page (Note: If the pagination is disabled, it will still take the value of pageandpageSize). | 
When using Row grouping, it can be useful to remove the groups from the CSV export.
CSV export
Exported cells
When the value of a field is an object or a renderCell is provided, the CSV export might not display the value correctly.
You can provide a valueFormatter with a string representation to be used.
<DataGrid
  columns={[
    {
      field: 'progress',
      valueFormatter: (value) => `${value * 100}%`,
      renderCell: ({ value }) => <ProgressBar value={value} />,
    },
  ]}
/>
File encoding
You can use csvOptions to specify the format of the export, such as the delimiter character used to separate fields, the fileName, or utf8WithBom to prefix the exported file with UTF-8 Byte Order Mark (BOM).
For more details on these options, please visit the csvOptions API page.
// Default toolbar:
<DataGrid
  slotProps={{
    toolbar: {
      csvOptions: {
        fileName: 'customerDataBase',
        delimiter: ';',
        utf8WithBom: true,
      },
    },
  }}
/>
// Custom trigger:
<ExportCsv
  options={{
    fileName: 'customerDataBase',
    delimiter: ';',
    utf8WithBom: true,
  }}
/>
Escape formulas
By default, the formulas in the cells are escaped. This is to prevent the formulas from being executed when the CSV file is opened in Excel.
If you want to keep the formulas working, you can set the escapeFormulas option to false.
// Default toolbar:
<DataGrid slotProps={{ toolbar: { csvOptions: { escapeFormulas: false } } }} />
// Custom trigger:
<ExportCsv options={{ escapeFormulas: false }} />
Print export
Modify the Data Grid style
By default, the printed grid is equivalent to printing a page containing only the Data Grid.
To modify the styles used for printing, such as colors, you can either use the @media print media query or the pageStyle property of printOptions.
For example, if the Data Grid is in dark mode, the text color will be inappropriate for printing (too light).
With media query, you have to start your sx object with @media print key, such that all the style inside are only applied when printing.
<DataGrid
  sx={{
    '@media print': {
      '.MuiDataGrid-main': { color: 'rgba(0, 0, 0, 0.87)' },
    },
  }}
  {/* ... */}
/>
With pageStyle option, you can override the main content color with a more specific selector.
// Default toolbar:
<DataGrid
  slotProps={{
    toolbar: {
      printOptions: {
        pageStyle:
          '.MuiDataGrid-root .MuiDataGrid-main { color: rgba(0, 0, 0, 0.87); }',
      },
    },
  }}
/>
// Custom trigger:
<ExportPrint options={{ pageStyle: '.MuiDataGrid-root .MuiDataGrid-main { color: rgba(0, 0, 0, 0.87); }' }} />
Customize grid display
By default, the print export displays all the DataGrid. It is possible to remove the footer and the toolbar by setting respectively hideFooter and hideToolbar to true.
// Default toolbar:
<DataGrid
  slotProps={{
    toolbar: {
      printOptions: {
        hideFooter: true,
        hideToolbar: true,
      },
    },
  }}
/>
// Custom trigger:
<ExportPrint options={{ hideFooter: true, hideToolbar: true }} />
If rows are selected when exporting, the checkboxes will not be included in the printed page. To export the checkboxes you can set includeCheckboxes to true.
// Default toolbar:
<DataGrid
  slotProps={{
    toolbar: {
      printOptions: {
        includeCheckboxes: true,
      },
    },
  }}
/>
// Custom trigger:
<ExportPrint options={{ includeCheckboxes: true }} />
For more options to customize the print export, please visit the printOptions API page.
Custom export format
You can add custom export formats the Data Grid by creating a custom toolbar and export menu. The demo below shows how to add a custom JSON export option.
Excel export
This feature relies on exceljs. With Excel export, users can translate the column types and tree structures of a Data Grid to an Excel file.
Columns with types 'boolean', 'number', 'singleSelect', 'date', and 'dateTime' are exported in their corresponding type in Excel. Please ensure the rows values have the correct type, you can always convert them as needed.
The excel export option will appear in the default toolbar export menu by passing the showToolbar prop to <DataGridPremium />, as shown in the demo below.
The export option can be added to custom toolbars using the Export Excel component.
Customization
Customizing the columns
You can use the columnsStyles property to customize the column style.
This property accepts an object in which keys are the column field and values an exceljs style object.
This can be used to specify value formatting or to add some colors.
// Default toolbar:
<DataGridPremium
  slotProps={{
    toolbar: {
      excelOptions: {
        columnsStyles: {
          // replace the dd.mm.yyyy default date format
          recruitmentDay: { numFmt: 'dd/mm/yyyy' },
          // set this column in green
          incomes: { font: { argb: 'FF00FF00' } },
        },
      },
    },
  }}
/>
// Custom trigger:
<ExportExcel
  options={{
    columnsStyles: {
      recruitmentDay: { numFmt: 'dd/mm/yyyy' },
      incomes: { font: { argb: 'FF00FF00' } },
    },
  }}
/>
Customizing the document
You can customize the document using two callback functions:
- exceljsPreProcesscalled before adding the rows' dataset.
- exceljsPostProcesscalled after the dataset has been exported to the document.
Both functions receive { workbook, worksheet } as input.
These are exceljs objects that let you directly manipulate the Excel file.
Thanks to these two methods, you can modify the metadata of the exported spreadsheet. You can also use it to add custom content on top or bottom of the worksheet, as follows:
function exceljsPreProcess({ workbook, worksheet }) {
  workbook.created = new Date(); // Add metadata
  worksheet.name = 'Monthly Results'; // Modify worksheet name
  // Write on first line the date of creation
  worksheet.getCell('A1').value = `Values from the`;
  worksheet.getCell('A2').value = new Date();
}
function exceljsPostProcess({ worksheet }) {
  // Add a text after the data
  worksheet.addRow(); // Add empty row
  const newRow = worksheet.addRow();
  newRow.getCell(1).value = 'Those data are for internal use only';
}
// ...
// Default toolbar:
<DataGridPremium
  slotProps={{
    toolbar: {
      excelOptions: {
        exceljsPreProcess,
        exceljsPostProcess,
      },
    },
  }}
/>
// Custom trigger:
<ExportExcel
  options={{
    exceljsPreProcess,
    exceljsPostProcess,
  }}
/>
Since exceljsPreProcess is applied before adding the content of the Data Grid, you can use it to add some informative rows on top of the document.
The content of the Data Grid will start on the next row after those added by exceljsPreProcess.
To customize the rows after the Data Grid content, you should use exceljsPostProcess. As it is applied after adding the content, you can also use it to access the generated cells.
In the following demo, both methods are used to set a custom header and a custom footer.
Using a web worker
Instead of generating the Excel file in the main thread, you can delegate the task to a web worker. This method reduces the amount of time that the main thread remains frozen so users can interact with the grid while the data is exported in background. To start using web workers for the Excel export, first you need to create a file with the content below. This file will be later used as the worker script, so it must be accessible by a direct URL.
// in file ./worker.ts
import { setupExcelExportWebWorker } from '@mui/x-data-grid-premium/setupExcelExportWebWorker';
setupExcelExportWebWorker();
The final step is to pass the path to the file created to excel options or the API method:
// Default toolbar:
<DataGridPremium
  slotProps={{
    toolbar: {
      excelOptions: {
        worker: () => new Worker('/worker.ts'),
      },
    },
  }}
/>;
// Custom trigger:
<ExportExcel
  options={{
    worker: () => new Worker('/worker.ts'),
  }}
/>;
// API method:
apiRef.current.exportDataAsExcel({
  worker: () => new Worker('/worker.ts'),
});
Since the main thread is not locked while the data is exported, it is important to give feedback for users that something is in progress.
You can pass a callback to the onExcelExportStateChange prop and display a message or loader.
The following demo contains an example using a Snackbar:
Escape formulas
By default, the formulas in the cells are escaped. This is to prevent the formulas from being executed when the file is opened in Excel.
If you want to keep the formulas working, you can set the escapeFormulas option to false.
// Default toolbar:
<DataGridPremium slotProps={{ toolbar: { excelOptions: { escapeFormulas: false } } }} />
// or
<ExportExcel options={{ escapeFormulas: false }} />
Clipboard
The clipboard export lets you copy the content of the Data Grid to the clipboard. For more information, check the Clipboard copy docs.
apiRef
The Data Grid exposes a set of methods via the apiRef object that are used internally in the implementation of the export feature.
The reference below describes the relevant functions.
See API object for more details.
CSV
Signature:
exportDataAsCsv: (options?: GridCsvExportOptions) => voidSignature:
getDataAsCsv: (options?: GridCsvExportOptions) => stringSignature:
exportDataAsPrint: (options?: GridPrintExportOptions) => voidSignature:
exportDataAsExcel: (options?: GridExcelExportOptions) => Promise<void>Signature:
getDataAsExcel: (options?: GridExcelExportOptions) => Promise<Excel.Workbook> | null