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下起作用)(可有可无)

 

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

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

(0)
上一篇 2022年8月4日 下午6:00
下一篇 2022年8月4日 下午6:16


相关推荐

  • 中国将划分成50个省 附最新50省地图

    中国将划分成50个省 附最新50省地图中国将划分成50个省附最新50省地图…

    2022年8月1日
    27
  • 关于三极管的理解—根据IC符号简易迅速判断三极管导通情况

    关于三极管的理解—根据IC符号简易迅速判断三极管导通情况  很不幸,开始写博客的第一天就被师兄批评了。其实很对不起师兄,当年在大学学习模拟电路的时候我不太认真,那时候天天忙着和女朋友吃吃喝喝。。所以对于三极管的各种性质与基本运用场景缺乏较深的理解,仅仅只是知道导通、截止等几种判断方式而已。今天在设计电路时涉及到了运用三极管驱动光耦器件,以及通过三极管来驱动蜂鸣器等操作,在三极管的选材和设计上出现了低级的失误。检讨完毕后,翻出当年的模电书,配…

    2022年6月17日
    44
  • servu搭建ftp服务器教程_ftp端口映射

    servu搭建ftp服务器教程_ftp端口映射映口映射的功能主要就是实际互联网可以访问当前进行映射的电脑,首先我们要进行路由器的端口映射,常见的开放端口有80,21,3389等,80是网站常用端口,21是FTP服务器常用端口,3389是远程桌面连接端口。下面为大家详细讲解端口映射的具体方法!1,首先我们要了解路由器的配置介面的IP地址,常用的是192.168.0.1或192.168.1.1,假如你不知道自己的路由器的配置页面的IP

    2025年10月29日
    1
  • 语音信号处理知识点

    语音信号处理知识点语音信号处理过程的总体结构:语音输入–&gt;预处理–&gt;数字化–&gt;特征提取预处理:对信号适当放大和增益控制,并进行反混叠滤波来消除工频信号干扰数字化:进行A/D转换特征提取:用反映语音信号特点的若干参数来代表语言 共振峰:当把声道看成一个发音的腔体的时候,激励的频率达到他的固有频率,则声道会以最大的振幅来振荡,即产生共鸣,这个频率称为共振频率(forman…

    2022年5月26日
    35
  • 太阳高度角方位角计算公式_太阳高度角方位角

    太阳高度角方位角计算公式_太阳高度角方位角太阳高度角/方位角计算公式本文不在此介绍太阳高度角、方位角是什么,相关概念请移步Wikipedia。鉴于很多相关专业人员需要计算太阳高度角、方位角,而网上介绍的公式多数或是不正确,或是杂乱无章。作者

    2022年8月1日
    8
  • 关系数据库模型设计「建议收藏」

    关系数据库模型设计「建议收藏」本文从现实世界-概念世界(信息世界)-机器世界(数据世界)逐级抽象,旨在以浅显易懂的语言描述关系数据库应该如何建模,最后用简单名了的描述给出关系模型的设计范式的含义。

    2022年7月16日
    20

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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