excel 导出json_导出的数据格式不对

excel 导出json_导出的数据格式不对json格式数据转Excel导出的两种方法第一种table格式数据直接转Excel:但是用这种方式会出现一种问题,就是当你的table有分页的情况下,只能抓取当前分页的数据。拿到表格的id就可以

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

json格式数据转Excel导出的两种方法

第一种table格式数据直接转Excel:

但是用这种方式会出现一种问题,就是当你的table有分页的情况下,只能抓取当前分页的数据。

excel 导出json_导出的数据格式不对

拿到表格的id就可以抓取表格的数据,导出到excel,这种方式简单粗暴,引入这两个插件即可。

excel 导出json_导出的数据格式不对

 

第一种方法问题奥特曼变身:将json数据转为table数据再进行Excel导出,

使用起来也比较简单,拿到数据直接往里面塞就是了,最后调用方法。这样的话最终所有数据都出来了。

excel 导出json_导出的数据格式不对

 

excel 导出json_导出的数据格式不对

 

function JSONToExcelConvertor(JSONData, FileName, ShowLabel) {
 
var arrData = typeof JSONData != ‘object’ ? JSON.parse(JSONData) : JSONData;
 
var excel = ‘<table>’;
 
//设置表头
var row = “<tr>”;
for (var i = 0, l = ShowLabel.length; i < l; i++) {
         row += “<td>” + ShowLabel[i].value + ‘</td>’;
}
 
//换行
excel += row + “</tr>”;
 
//设置数据
for (var i = 0; i < arrData.length; i++) {
     var row = “<tr>”;
 
   for(var j=0;j<arrData[i].length;j++){
     var value = arrData[i][j].value === “.” ? “” : arrData[i][j].value;
     row += ‘<td>’ + value + ‘</td>’;
  }

   excel += row + “</tr>”;
}
 
excel += “</table>”;
 
var excelFile = “<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′>”;
excelFile += ‘<meta http-equiv=”content-type” content=”application/vnd.ms-excel; charset=UTF-8″>’;
excelFile += ‘<meta http-equiv=”content-type” content=”application/vnd.ms-excel’;
excelFile += ‘; charset=UTF-8″>’;
excelFile += “<head>”;
excelFile += “<!–[if gte mso 9]>”;
excelFile += “<xml>”;
excelFile += “<x:ExcelWorkbook>”;
excelFile += “<x:ExcelWorksheets>”;
excelFile += “<x:ExcelWorksheet>”;
excelFile += “<x:Name>”;
excelFile += “{worksheet}”;
excelFile += “</x:Name>”;
excelFile += “<x:WorksheetOptions>”;
excelFile += “<x:DisplayGridlines/>”;
excelFile += “</x:WorksheetOptions>”;
excelFile += “</x:ExcelWorksheet>”;
excelFile += “</x:ExcelWorksheets>”;
excelFile += “</x:ExcelWorkbook>”;
excelFile += “</xml>”;
excelFile += “<![endif]–>”;
excelFile += “</head>”;
excelFile += “<body>”;
excelFile += excel;
excelFile += “</body>”;
excelFile += “</html>”;
 
 
var uri = ‘data:application/vnd.ms-excel;charset=utf-8,’ + encodeURIComponent(excelFile);
 
var link = document.createElement(“a”);
link.href = uri;
 
link.style = “visibility:hidden”;
link.download = FileName + “.xls”;
 
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
}
var JSON_DATA = {
    “title”:[
                 {“value”:”司机”, “type”:”ROW_HEADER_HEADER”, “datatype”:”string”},
                 {“value”:”日期”, “type”:”ROW_HEADER_HEADER”, “datatype”:”string”},
                 {“value”:”物流单数量”, “type”:”ROW_HEADER_HEADER”, “datatype”:”string”},
                 {“value”:”退货单数量”, “type”:”ROW_HEADER_HEADER”, “datatype”:”string”},
                 {“value”:”发货总件数”, “type”:”ROW_HEADER_HEADER”, “datatype”:”string”},
                 {“value”:”退货总件数”, “type”:”ROW_HEADER_HEADER”, “datatype”:”string”},
                 {“value”:”拒收总件数”, “type”:”ROW_HEADER_HEADER”, “datatype”:”string”},
                 {“value”:”取消发货总件数”, “type”:”ROW_HEADER_HEADER”, “datatype”:”string”},
                 {“value”:”物流费总金额    “, “type”:”ROW_HEADER_HEADER”, “datatype”:”string”},
                 {“value”:”代收手续费总金额”, “type”:”ROW_HEADER_HEADER”, “datatype”:”string”},
                 {“value”:”代收货款总金额”, “type”:”ROW_HEADER_HEADER”, “datatype”:”string”}
        ],
       “data”:[
 
        ] 
};
第二种方法使用插件直接对json数据进行转换  插件 JsonExportExcel.min.js

1.引入js (dist目录下JsonExportExcel.min.js)

<script src="https://cuikangjie.github.io/JsonExportExcel/dist/JsonExportExcel.min.js"></script>

npm install -save  js-export-excel
const ExportJsonExcel = require('js-export-excel')

2.js代码

复制代码
 1 var option={};
 2 
 3 option.fileName = 'excel'
 4 option.datas=[
 5   {
 6    //第一个sheet
 7     sheetData:[{one:'一行一列',two:'一行二列'},{one:'二行一列',two:'二行二列'}],
 8     sheetName:'sheet',
 9     sheetFilter:['two','one'],
10     sheetHeader:['第一列','第二列']
11   },
12   {
13     //第二个sheet
14     sheetData:[{one:'一行一列',two:'一行二列'},{one:'二行一列',two:'二行二列'}]
15   }
16 ];
17 var toExcel=new ExportJsonExcel(option);
18 toExcel.saveExcel();
复制代码

option

datas 数据

/*多个sheet*/ /*每个sheet为一个object */ 
[{ sheetData:[], // 数据
    sheetName:'', // sheet名字 
    sheetFilter:[], //列过滤 
    sheetHeader:[] // 第一行 
}]

fileName 下载文件名(默认:download)

sheet option

sheetName sheet名字(可有可无)(默认sheet1)

sheetHeader 标题(excel第一行数据)

sheetData 数据源(必须)

sheetFilter 列过滤(只有在data为object下起作用)(可有可无)

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/167808.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • android onresume方法,Android onActivityResult()和onResume()的执行顺序

    android onresume方法,Android onActivityResult()和onResume()的执行顺序问题回顾:在Android8.0手机上不能直接安装Apk,需要权限申请,回调后执行onActivityResult()方法,并弹出对应的dialog,这时需要判断当前Activity是否处于resume状态,通过变量来控制,但结果是这个dialog并不会弹出。问题本质Activity跳转到系统应用后回调onActivityResult()先执行还是onResume()先执行?查看源码/***C…

  • Android Settings开发之修改

    Android Settings开发之修改版本:1.0 日期:2014.3.20 2014.3.25  版权:©2014kince转载注明出处        下面是Seeings应用的截图:  可以看出这是很典型的使用了Fragment后的界面,设置里面有WIFI、蓝牙、显示、存储、应用等众多功能。左边的每一项,对应着右边的一个设置界面,Fragment有四个子类:DialogFragment,ListFragme

  • aliddns ipv6_群晖使用阿里云DDNS(ipv4和ipv6)「建议收藏」

    aliddns ipv6_群晖使用阿里云DDNS(ipv4和ipv6)「建议收藏」复制,写成sh脚本,添加进群晖定时任务即可。ipv4注意前四个需要自己填入,还有获取ip那里要注意网络接口,我的是ppp0。#!/bin/shApiId=”***************”ApiKey=”***************”Domain=’************’SubDomain=’********’#这四个自己写Nonce=$(date-u”+%N”)Timest…

  • Ubuntu之cudnn安装

    Ubuntu之cudnn安装一、cudnn简介二、安装步骤

  • linux 驱动移植_免驱动led灯好吗

    linux 驱动移植_免驱动led灯好吗通过前两篇文章的介绍,我们已经把linux内核移植到了tiny210上,但是看到的现象都是通过超级终端来观察的,下面了,我们介绍一下led灯的移植,给大家一个更直观的感受。这篇文章主要的内容如下:1.对平台总线的简介;2.led驱动的移植。一.平台总线   首先介绍一下,我们为什么要简单介绍一下平台总线呢?因为我们是做led驱动的移植,而不是自己编写led的驱动代码。我们要移植

  • C语言代码的换行_c语言怎么换行输出

    C语言代码的换行_c语言怎么换行输出分两种情况:1.预处理:把一个预处理指示写成多行要用“\”续行,因为根据定义,一条预处理指示只能由一个逻辑代码行组成。2. 正常程序:一行写不下:把C代码写成多行则不必使用续行符,因为

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号