H5前端JS将json数据导出为excel

方法一:拼接json字符串输出为csv文件

通过对json格式的数据进行遍历,字符串拼接,通过a标签将拼接好的字符串输出到csv文件,csv文件可以用excel打开

, :每一个逗号就是隔开一个单元格

\t :为了不让表格显示科学计数法或者其他格式

\n :换行

const data = [
{
    user_id: '小明',
    history_turns: [
        {"rob":"请告诉我您的出生日期,以便我能为您更好提供调理建议。","user":"2000/2/5"},
        {"rob":"睡眠质量常受工作影响,不同职业人群的睡眠条件不尽相同,请问您的职业属于以下哪类?","user":"学生"}
    ]
},
{
    user_id: '老张',
    history_turns: [
        {"rob":"请告诉我您的出生日期,以便我能为您更好提供调理建议。","user":"1999/2/5"},
        {"rob":"睡眠质量常受工作影响,不同职业人群的睡眠条件不尽相同,请问您的职业属于以下哪类?","user":"老师"}
    ]
}];
<html>
<head>
    <h1>使用a标签方式将json导出为csv文件</h1>
    <button onclick='jsonToExcel()'>导出</button>
</head>

<body>
  <script src="./data.js"></script>

  <script>
    const jsonToExcel = () => {
        // 要导出的json数据
        const jsonData = data

        // 列标题,逗号隔开,每一个逗号就是隔开一个单元格
        let str = `姓名,问题,答案\n`;

        // 增加 \t 为了不让表格显示科学计数法或者其他格式
        for(let i = 0 ; i < jsonData.length ; i++ ){
          str += `${(i+1) + ' 、' + jsonData[i].user_id + '\t'},`;
          for(let j = 0; j < jsonData[i].history_turns.length; j++) {
            if(j !== 0){
              str += `${''+'\t'},`
            }

            for(const key in jsonData[i].history_turns[j]) {
              str += `${jsonData[i].history_turns[j][key] + '\t'},`;   
            }
            
            // \n 换行
            str+='\n';
          }
          str+='\n';
        }

        // encodeURIComponent解决中文乱码
        const uri = 'data:text/csv;charset=utf-8,\ufeff' + encodeURIComponent(str);
        // 通过创建a标签实现
        const link = document.createElement("a");
        link.href = uri;
        // 对下载的文件命名
        link.download =  "用户数据表.csv";
        link.click();
    }
  </script>
</body>
</html>

方法二、 使用table标签输出为xls文件

将table标签,包括tr、td等标签对json数据进行拼接,将table输出到表格上实现导出excel,格式为xls

弊端:输出的是伪excel,虽然生成后缀为xls的文件,但文件形式上还是html

<html>
<head>
    <h1>使用table标签方式将json数据导出为xls文件</h1>
    <button onclick='tableToExcel()'>导出</button>
</head>
<body>

<script>  
    const tableToExcel = () => {
        // 要导出的json数据
        const jsonData = [
            {
                name:'用户1',
                age: 1,
                sex: '男'
            },
            {
                name:'用户2',
                age: 2,
                sex: '女'
            }];

        // 列标题
        let str = '<tr><td>姓名</td><td>年龄</td><td>性别</td></tr>';

        // 循环遍历,每行加入tr标签,每个单元格加td标签
        for(let i = 0 ; i < jsonData.length ; i++ ){
            str+='<tr>';

            for(const key in jsonData[i]){
                // 增加\t为了不让表格显示科学计数法或者其他格式
                str+=`<td>${ jsonData[i][key] + '\t'}</td>`;     
            }
            str+='</tr>';
        }

        // Worksheet名
        const worksheet = 'Sheet1'
        const uri = 'data:application/vnd.ms-excel;base64,';
 
        // 下载的表格模板数据
        const template = `<html xmlns:o="urn:schemas-microsoft-com:office:office" 
        xmlns:x="urn:schemas-microsoft-com:office:excel" 
        xmlns="http://www.w3.org/TR/REC-html40">
        <head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet>
        <x:Name>${worksheet}</x:Name>
        <x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet>
        </x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]-->
        </head><body><table>${str}</table></body></html>`;
        // 下载模板
        window.location.href = uri + base64(template);
    };
 
    // 输出base64编码
    const base64 = s => window.btoa(unescape(encodeURIComponent(s)));

</script>
</body>
</html>

猜你喜欢

转载自blog.csdn.net/qq_31851435/article/details/128921802