DataShift

Convert CSV to XML Online

Convert a CSV file to valid XML — with configurable root and row element names.

CSV → XML

Free CSV to XML converter. Each CSV row becomes an XML element, with column headers as child tags. Configurable root and row element names. Works in your browser.

100% local — no uploads
Input · CSV

Output will appear here

How to use the CSV → XML

  1. Paste or upload your CSV data

    Paste text directly into the input box, drag and drop a file onto it, or click "Upload file" to browse. Conversion starts instantly on paste — no button click required.

  2. Configure options (optional)

    Open the Options panel to customise delimiter, headers, nested-object flattening, and more. Use the Field Selector to pick exactly which columns appear in the output.

  3. Copy or download your XML

    Click Copy to grab the result, or Download to save the file. Everything runs locally in your browser — no data ever leaves your device.

Frequently Asked Questions

Is my data safe?
Yes. Every conversion runs entirely inside your browser. No data is ever transmitted to a server. The tool works offline once loaded.
What is the maximum file size?
There is no hard limit. Files under 1 MB convert instantly. Files 1–10 MB show a progress indicator. Files over 10 MB prompt a warning and run in a background thread to keep the browser responsive.
Why does my CSV fail to parse?
Common causes are trailing commas, single-quoted strings, unquoted keys, or missing closing brackets. The converter auto-repairs many of these and tells you exactly what it changed.
Can I convert multiple files at once?
The tool handles one file at a time. For bulk conversion, consider the csvjson CLI or API.

How it works

Step 1

Each row becomes an XML element

Column headers become child element names. The root element and per-row element name are both configurable.

Example

Contact list to XML

Input
name,email,phone
Alice,alice@example.com,555-0001
Output
<?xml version="1.0"?>
<contacts>
  <contact>
    <name>Alice</name>
    <email>alice@example.com</email>
    <phone>555-0001</phone>
  </contact>
</contacts>

Frequently asked questions

Can I set the element names?

Yes. The root element defaults to 'root' and the row element to 'item'. Both are configurable in the options panel.