json导出excel(条数不受限)

接上文:json导出excel(条数受限)

因为自己写的超过1w条会出现下载失败,所以就各种搜资料,然后github搜到一个插件:jsonExportExcel

目前是用mock测试了3w条数据,简直是秒导出(我们系统好像只会保存3w条,所以我只测试3w条就ok了)

动手

引入: 这里引入mock.js是为了等下测试多数据

<script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdn.bootcss.com/Mock.js/1.0.1-beta3/mock-min.js"></script>
<script src="../js/jsonExportExcel.js"></script>

官网示例

window.onload=function () {
    var option={};

    option.fileName = 'excel'
    option.datas=[
      {
        sheetData:[{one:'一行一列',two:'一行二列'},{one:'二行一列',two:'二行二列'}],
        sheetName:'sheet',
        //sheetFilter:['two','one'], 可有可无
        sheetHeader:['第一列','第二列']
      },
      /*
      {
        sheetData:[{one:'一行一列',two:'一行二列'},{one:'二行一列',two:'二行二列'}],
        sheetName:'sheet',
        //sheetFilter:['two','one'], 可有可无
        sheetHeader:['第一列','第二列']
      }
      */
    ];
    var toExcel=new ExportJsonExcel(option);
    toExcel.saveExcel();
}
mock测试
Mock.mock(
    'http://mockjs', {
        'tableData|30000':[{
            "userName": '@name', //模拟名称
            "age|1-100": 100, //模拟年龄(1-100)
            "color": "@color", //模拟色值
            "date": "@date('yyyy-MM-dd')", //模拟时间
            "url": "@url()", //模拟url
        }]

    }
);
var option={};
option.fileName = 'excel'
option.datas=[
    {
        sheetData:'',
        sheetName:'sheet',
        // sheetFilter:['userNam','age','color','date','url'],
        sheetHeader:['名字','年龄','颜色','日期','地址'],
    }
];
$.ajax({
    url: "http://mockjs", //请求的url地址
    dataType: "json", //返回格式为json
    async: false, //请求是否异步,默认为异步,这也是ajax重要特性
    data: {}, //参数值
    type: "GET", //请求方式
    success:function(res){
        console.log(res.tableData);
        option.datas[0].sheetData = res.tableData;  
        // if(res.tableDate == 0)  return;                                                        
    }
});
console.log(option)
var toExcel=new ExportJsonExcel(option);


$(document).ready(function(){
    $('#wwo').click(function(){
              toExcel.saveExcel();     
    });
});
效果

看到右边打印说明我mock的3w条数据是ok的,然后点击打印下载的excel文件也包含了3w条数据
效果

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Aspose.Cells可以通过使用Smart Markers来将JSON数据导出Excel中。Smart Markers是一种特殊的标记语法,可以在Excel模板中定义,并在填充数据时使用。你可以在Aspose.Cells的官方文档中找到有关Smart Markers的更多信息\[1\]。 以下是一个简单的实现读取和导出Excel的操作类的示例代码\[2\]: ```java import com.aspose.cells.Workbook; import com.aspose.cells.Worksheet; import com.aspose.cells.Cells; import com.aspose.cells.Cell; import com.aspose.cells.SaveFormat; public class ExcelExporter { public static void exportToExcel(String jsonData, String templatePath, String outputPath) throws Exception { Workbook workbook = new Workbook(templatePath); Worksheet worksheet = workbook.getWorksheets().get(0); Cells cells = worksheet.getCells(); // 在模板中定义Smart Markers cells.replace("{data}", jsonData); // 保存Excel文件 workbook.save(outputPath, SaveFormat.XLSX); } } ``` 你可以将上述代码中的`jsonData`替换为你的JSON数据,`templatePath`替换为你的Excel模板路径,`outputPath`替换为你想要保存的Excel文件路径。然后调用`exportToExcel`方法即可将JSON数据导出Excel中。 希望这个例子能帮到你。如果你需要更多关于Aspose.Cells的信息,请访问官方文档\[1\]。 #### 引用[.reference_title] - *1* *2* [用ASPOSE.Cells将HTML表格存为Excel](https://blog.csdn.net/weixin_34337134/article/details/118263891)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [使用Aspose.Cells导出excel](https://blog.csdn.net/rxbtalent/article/details/99818241)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值