一、上传excel文件,得到InputStream,由InputStream得到Jxl中的Workbook,取出内容,存到二维数组中。

1、使用 Jquery Uploadify 插件(http://www.uploadify.com/ ),得到FileItem,由FileItem得到InputStream。

  1. String[][] excelContent = getExcelContent(fileItem.getInputStream());

2、将Excel内容存放到二维数组中。

  1. public String[][] getExcelContent(InputStream is) {
  2. try {
  3. Workbook workBook = Workbook.getWorkbook(is);
  4. Sheet sheet = workBook.getSheet(0);
  5. int sheetColumns = sheet.getColumns();
  6. int sheetRows = sheet.getRows();
  7. // excel内容
  8. String[][] excelContent = new String[sheetRows][sheetColumns];
  9. for (int i = 0; i < sheetRows; i++) {
  10. for (int j = 0; j < sheetColumns; j++) {
  11. // 将excel值放入二维数组excelContent中
  12. excelContent[i][j] = sheet.getCell(j, i).getContents();
  13. }
  14. }

二、将二维数组转换成JSON(stringBuffer)格式为:[{"filed1":,"value"},{"filed2":,"value2"}]

  1. stringBuffer = convertToJson(excelContent);

拼字符串花了我很多时间

  1. private static final String QUOTATION_MARKS = "\""; //双引号
  2. private static final String COMMA = ","; //逗号
  3.  
  4. public StringBuffer convertToJson(String[][] srcArray) {
  5.  
  6. StringBuffer stringBuffer = new StringBuffer();
  7. boolean first = true;
  8. stringBuffer.append("[");
  9.  
  10. for (int i = 0; i < srcArray.length; i++) {
  11. String[] arrayItem = srcArray[i];
  12. if (!first) {
  13. stringBuffer.append(COMMA);
  14. }
  15. stringBuffer.append("{");
  16.  
  17. boolean first2 = true;
  18. for (int j = 0; j < arrayItem.length; j++) {
  19.  
  20. if (!first2) {
  21. stringBuffer.append(COMMA);
  22. }
  23. stringBuffer.append(QUOTATION_MARKS + "field" + j
  24. + QUOTATION_MARKS + ":\"" + arrayItem[j]
  25. + QUOTATION_MARKS);
  26. first2 = false;
  27. }
  28. stringBuffer.append("}");
  29. first = false;
  30. }
  31.  
  32. stringBuffer.append("]");
  33. return stringBuffer;
  34.  
  35. }

 三、生成可用于DataGrid加载的Json格式,即 {"total":n,"rows":[{"filed1":,"value"},{"filed2":,"value2"}]}。

  1. sheetRows = excelContent.length;
  2. sheetColumns = excelContent[0].length;
  3.  
  4. StringBuffer stringBuffer2 = new StringBuffer("");
  5. stringBuffer2.append("{");
  6. stringBuffer2.append(QUOTATION_MARKS + "total"
  7. + QUOTATION_MARKS + ":" + sheetRows + COMMA
  8. + QUOTATION_MARKS + "rows" + QUOTATION_MARKS + ":");
  9. stringBuffer2.append(stringBuffer);
  10. stringBuffer2.append("}");

http://bbs.csdn.net/topics/390395096

使用jxl读取excel内容,并转换成Json,用于Datagrid的更多相关文章

  1. 分享一个小工具:Excel表高速转换成JSON字符串

    在游戏项目中一般都须要由策划制作大量的游戏内容,当中非常大一部分是使用Excel表来制作的.于是程序就须要把Excel文件转换成程序方便读取的格式. 之前项目使用的Excel表导入工具都是通过Offi ...

  2. JAVA利用jxl读取Excel内容

    JAVA可以利用jxl简单快速的读取文件的内容,但是由于版本限制,只能读取97-03  xls格式的Excel. import java.io.File; import java.io.FileInp ...

  3. C#读取数据库内容并转换成xml文件

    OleDbConnection conn = new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\bi ...

  4. C# Excel转换成Json工具(含源码)

    可执行版本下载:https://github.com/neil3d/excel2json/releases 完整项目源代码下载:https://github.com/neil3d/excel2json ...

  5. python如何转换word格式、读取word内容、转成html

    # python如何转换word格式.读取word内容.转成html? import docx from win32com import client as wc # 首先将doc转换成docx wo ...

  6. 【游戏开发】Excel表格批量转换成lua的转表工具

    一.简介 在上篇博客<[游戏开发]Excel表格批量转换成CSV的小工具> 中,我们介绍了如何将策划提供的Excel表格转换为轻便的CSV文件供开发人员使用.实际在Unity开发中,很多游 ...

  7. EasyExcel 轻松灵活读取Excel内容

    写在前面 Java 后端程序员应该会遇到读取 Excel 信息到 DB 等相关需求,脑海中可能突然间想起 Apache POI 这个技术解决方案,但是当 Excel 的数据量非常大的时候,你也许发现, ...

  8. POI读取Excel内容格式化

    在用POI读取Excel内容时,经常会遇到数据格式化的问题. 比如:数字12365会变为12365.0;字符串数字123也会变为123.0,甚至会被变为科学计数法.另外日期格式化也是一个头疼的问题.其 ...

  9. C# 读取Excel内容

    一.方法 1.OleD方法实现该功能. 2.本次随笔内容只包含读取Excel内容,并另存为. 二.代码 (1)找到文档代码 OpenFileDialog openFile = new OpenFile ...

随机推荐

  1. 解决在cmder中bash(WSL)上下箭头不能使用问题

    有三种解决方式,第一种方式最简单实用 安装新版本wslbridge 这个解决方法最简单,最实用,下载第三方wslbridge,安装即可使用. 这时再进入cmder,运行bash.exe,可以发现上下左 ...

  2. 为什么 kubernetes 天然适合微服务 (3)

    此文已由作者刘超授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验 四.Kubernetes 本身就是微服务架构 基于上面这十个设计要点,我们再回来看 Kubernetes,会发现 ...

  3. 预定义宏,C语言预定义的宏详解

    1.预定义宏 对于预定义宏,相信大家并不陌生.为了方便处理一些有用的信息,预处理器定义了一些预处理标识符,也就是预定义宏.预定义宏的名称都是以"__"(两条下划线)开头和结尾的,如 ...

  4. day2学python 数据类型+深浅拷贝+循环

    数据类型+深浅拷贝+循环 别的语言的数组 python不用定义 直接使用 color=['红','橙','黄','绿','青','蓝','紫'] print(color[1:3]) //打印[1,3) ...

  5. leetcode 106. 从中序与后序遍历序列构造二叉树(Construct Binary Tree from Inorder and Postorder Traversal)

    目录 题目描述: 示例: 解法: 题目描述: 根据一棵树的中序遍历与后序遍历构造二叉树. 注意: 你可以假设树中没有重复的元素. 示例: 给出 中序遍历 inorder = [9,3,15,20,7] ...

  6. kali linux之netcat

    网络工具中的瑞士军刀----体积小,功能强大 侦听模式/传输模式 telnet/获取banner信息 传输文本信息,文件,目录 加密传输文件,远程控制/木马,加密所有流量(来做远程控制是非常理想的选择 ...

  7. inspect模块---检查活动对象

    inspect模块提供了一些有用的函数来帮助获取有关活动对象(如模块,类,方法,函数,跟踪,框架对象和代码对象)的信息.例如,它可以帮助您检查类的内容,检索方法的源代码,提取和格式化函数的参数列表,或 ...

  8. php 写入csv时 双引号,逗号及特殊字符

    1.双引号 <?php function new_csv($string) { $filename = date('Ymd').'.csv'; //设置文件名 header("Cont ...

  9. office 2013 破解工具 及 软件下载

     win7/win8/win10  office2013 破解工具 下载地址: https://pan.baidu.com/s/1sZeJOCWq1fZ3KIOWvmrAQQ office2013  ...

  10. STM32F0 中 ADC 多通道转换结果相同的问题

    前言 前段时间调试 STM32F030 的 ADC,在多通道转换时遇到了奇怪的问题,使用官方的例程和库函数连续转换多个 ADC 通道,得到的几个通道的结果是一样的,解决办法参考了 关于STM32F0系 ...