假如我们有一段json串,该json串是由一系列结构相同的数据集合组成,如下:

{
"data": [
{
"groupId": "com.test.demo",
"artifactId": "demo-api",
"version": "1.0.0-release",
"latestSnapshot": "2.0.0-SNAPSHOT"
},
{
"groupId": "com.test.demo.core",
"artifactId": "demo-core",
"version": "1.1.3",
"latestSnapshot": "1.3.0-SNAPSHOT"
}
]
}

现在,想要转换成excel表单:

针对该需求,于是在网上找了个excel工具包。

现在将实现代码贴出来,希望给正有此需求的同仁些许帮助。

import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import lombok.extern.slf4j.Slf4j;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject; import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Iterator; /**
* @Author changle
* @Time 17/8/1.
* @Desc json转变为Excel演示
*/
@Slf4j
public class JsonToExcelDemo {
public static void main(String[] args) {
parseJsonToExcel("/var/tmp/jsonToExcel-demo.xls", "data", mavenInfos);
} static void parseJsonToExcel(String saveFileName, String rootNodeName, String sourceJson){
try{
File filewrite=new File(saveFileName);
filewrite.createNewFile();
OutputStream os = new FileOutputStream(filewrite);
JSONObject jsonObject = JSONObject.fromObject(sourceJson);
createExcel(os, jsonObject, rootNodeName);
log.info("解析完毕");
}catch (Exception e){
e.printStackTrace();
}
} public static void createExcel(OutputStream os, JSONObject apiJarInfos, String rootNodeName) throws WriteException,IOException {
//创建工作薄
WritableWorkbook workbook = Workbook.createWorkbook(os);
//创建新的一页
WritableSheet sheet = workbook.createSheet("First Sheet",);
JSONArray jsonArray = (JSONArray)apiJarInfos.get(rootNodeName);
JSONObject jsonObjectHeader = jsonArray.getJSONObject();
String[] headers = createTableHeader(jsonObjectHeader, sheet);
int size = jsonArray.size()+;
for(int i=; i<size; i++){
JSONObject jsonObject = jsonArray.getJSONObject(i-);
int j = ;
for (String key : headers){
Label cellValue = new Label(j, i, jsonObject.get(key).toString());
sheet.addCell(cellValue);
j++;
}
}
//把创建的内容写入到输出流中,并关闭输出流
workbook.write();
workbook.close();
os.close();
} static String[] createTableHeader(JSONObject jsonObjectHeader, WritableSheet sheet) throws WriteException {
//遍历JSONObject中的key
Iterator iterable = jsonObjectHeader.keys();
String[] headers = new String[jsonObjectHeader.size()];
int i = ;
while (iterable.hasNext()){
//创建要显示的内容,创建一个单元格,第一个参数为列坐标,第二个参数为行坐标,第三个参数为内容
String headerName = iterable.next().toString();
Label cell = new Label(i, , headerName);
sheet.addCell(cell);
headers[i] = headerName;
i++;
log.info(headerName);
}
return headers;
} private static final String mavenInfos ="{ \n" +
" \"data\": [\n" +
" {\n" +
" \"groupId\": \"com.test.demo\",\n" +
" \"artifactId\": \"demo-api\",\n" +
" \"version\": \"1.0.0-release\",\n" +
" \"latestSnapshot\": \"2.0.0-SNAPSHOT\"\n" +
" },\n" +
" {\n" +
" \"groupId\": \"com.test.demo.core\",\n" +
" \"artifactId\": \"demo-core\",\n" +
" \"version\": \"1.1.3\",\n" +
" \"latestSnapshot\": \"1.3.0-SNAPSHOT\"\n" +
" }\n" +
" ]\n" +
"}";
}

执行main方法,得到/var/tmp/api-sources.xls文件。和预想中的效果一样。

需要用到的jar包:

<dependency>
    <groupId>org.json</groupId>
    <artifactId>json</artifactId>
    <version>20160212</version>
</dependency>
<dependency>
    <groupId>java-excel-jxl</groupId>
    <artifactId>java-excel-jxl</artifactId>
    <version>1.0.0</version>
</dependency>

java-excel-jxl这个包请下载  https://jaist.dl.sourceforge.net/project/jexcelapi/jexcelapi/2.6.6/jexcelapi_2_6_6.zip  解压。

https://blog.csdn.net/skypig555/article/details/77623245

http://j2e.kpoda.com/

Json字符串转excel表格文件的更多相关文章

  1. php中读写excel表格文件示例。

    测试环境:php5.6.24.这块没啥兼容问题. 需要更多栗子,请看PHPExcel的examples.还是蛮强大的. 读取excel文件. 第一步.下载开源的PHPExcel的类库文件,官方网站是h ...

  2. pyhton读取 excel表格文件

    2019的第一天,忘记昨日之事,迎接新的明天. excel表格文件办公中常用,如通过Python操作这些数据需导入并有序读取这些数据 特随笔,供以后查阅 代码如下: import xlrd # fil ...

  3. python读取Excel表格文件

    python读取Excel表格文件,例如获取这个文件的数据 python读取Excel表格文件,需要如下步骤: 1.安装Excel读取数据的库-----xlrd 直接pip install xlrd安 ...

  4. Python读取Json字典写入Excel表格的方法

    需求: 因需要将一json文件中大量的信息填入一固定格式的Excel表格,单纯的复制粘贴肯定也能完成,但是想偷懒一下,于是借助Python解决问题. 环境: Windows7 +Python2.7 + ...

  5. PHP生成excel表格文件并下载

    本文引自网络,仅供自己学习之用. 利用php导出excel我们大多会直接生成.xls文件,这种方便快捷. function createtable($list,$filename){ header(& ...

  6. python操作excel表格文件--使用xlrd模块

    原文: http://www.cnblogs.com/lhj588/archive/2012/01/06/2314181.html 引言: 实际工作中,可能很多情况下都会用到excel表格,像如果不需 ...

  7. 在网页中预览excel表格文件

    项目需求在前端页面中实现预览excel表格的功能,上网了解之后大致总结为一下几种方法. 1.office文档转换为pdf,再转swf,然后通过网页加载flash进行预览 2.通过 xlsx.js,js ...

  8. Python 处理 CSV/EXCEL 表格文件

    只想说,数据挖掘工作,80%时间都花在处理数据上了,这句话真不假! 最近和小伙伴组了个队参加数据分析比赛,记录下我处理 csv 文件的一些步骤吧: 修改csv文件 可以用csv模块1,官方文档2 im ...

  9. 把txt文件中的json字符串写到plist文件中

    - (void)json2Plist { NSString *filePath = [self applicationDocumentsDirectoryFileName:@"json&qu ...

随机推荐

  1. 微信小程序网络请求wx.request请求

    最近微信小程序开始开放测试了,小程序提供了很多api,极大的方便了开发者,其中网络请求api是wx.request(object),这是小程序与开发者的服务器实现数据交互的一个很重要的api. 百牛信 ...

  2. CF-805B

    B. 3-palindrome time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...

  3. 转载 关于启用HTTPS的一些经验分享

    本文转载自  https://imququ.com/post/sth-about-switch-to-https.html 随着国内网络环境的持续恶化,各种篡改和劫持层出不穷,越来越多的网站选择了全站 ...

  4. 前端之CSS2

    CSS盒子模型 CSS盒子模型介绍 盒子模型解释 元素在页面中显示成一个方块,类似一个盒子,CSS盒子模型就是使用现实中盒子来做比喻,帮助我们设置元素对应的样式. 盒子模型示意图如下: 把元素叫做盒子 ...

  5. .NET 5 - 下一代.NET

    不知不觉中微软已经计划推出了下一代的.NET了,我们先来看一下新的.NET有包含什么 What's new in .NET 5? .NET 5将会引入新的APIs,运行时功能和新的语言特色. 在运行时 ...

  6. [WIP]webpack入门

    创建: 2019/04/09  安装 npm install --save-dev webpack # 最新版 npm install --save-dev webpack@<version&g ...

  7. 算法学习--Day10

    今天开始了新一章的学习,前面的题目虽然做了几道,但是我觉得训练量仍然太小了.不过机试确实很多题目,并且难度也有所不同,所以要针对不同的题目进行专门的练习才好.题目类型有些多,等接下来我将搜索的题目写完 ...

  8. Codeforces325 D【并查集维护连通性】

    参考:大牛blog 思路: 因为是环,所以可以复制一下图,先判断一下和他是不是和与他相邻的8个之一的一个障碍使得构成了一个环,环就是一个连通,用并查集维护即可: 如果没有就ans++,然后并把这个点加 ...

  9. CodeForces 382C【模拟】

    活生生打成了大模拟... #include <bits/stdc++.h> using namespace std; typedef long long LL; typedef unsig ...

  10. 51nod 1068【简单博弈】

    思路 手动打表, N 1 : A出1 A胜: 2 : A出2 A胜: 3 : A只能出2的整数幂&&这个数<=3,所以只能出1,2:A出1的时候,B就是2的情况,B胜:A出2的时 ...