一、上传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. touchmove和touchend的使用

    touchstart:当手指触摸屏幕时触发:即使已经有一个手指放在了屏幕上也会触发.touchmove:当手指在屏幕上滑动时连续的触发.在这个事件发生期间,调用preventDefault()可阻止滚 ...

  2. URLRewrite 实现方法详解

    所谓的伪静态页面,就是指的URL重写,在ASP.NET中实现非常简单首先你要在你的项目里引用两个DLL:ActionlessForm.dll.URLRewriter.dll,真正实现重写的是 URLR ...

  3. asp.net微信内置浏览器下Session失效

    问题记录:仅限安卓端微信内置浏览器,服务器集群设置了黏性Session,在Post请求时会强制走代理,导致出去的ip指向另一台服务器,黏性Session失效,用户状态无法保存. 目前想知道除了设置Se ...

  4. VINS-Mono Installation

    Prerequisites 1.1 ** Ubuntu 16.04, ROS Kinetic ** sudo apt-get install ros-kinetic-cv-bridge ros-kin ...

  5. kali linux之主动信息收集(三层发现,四层发现)

    三层发现: 比二层发现的优点即可路由,就是速度比二层慢,相对我们来说还是算快的,经常被边界防火墙过滤 ip icmp协议 OSI七层模型

  6. SpringBoot Maven多模块整合MyBatis 打包jar

    最近公司开始新的项目,框架选定为SpringBoot+Mybatis,本篇主要记录了在IDEA中搭建SpringBoot多模块项目的过程. 源码:https://github.com/12641561 ...

  7. CentOS71611部署Django

    web.conf <VirtualHost *:> WSGIScriptAlias / /var/www/datacn/datacn/wsgi.py Alias /static/ /var ...

  8. upsource代码审查

    upsource 从零搭建代码审查平台,需要的不仅是把代码审查的工具搭起来,还要结合公司情况制定一系列的代码审查规范.下面是对选择的upsource web端代码审查工具的安装及介绍.详细的请看这篇文 ...

  9. 查看db连接数sql

    /****** Object: StoredProcedure [dbo].[SP_Conn] Script Date: 12/09/2018 19:03:28 ******/ SET ANSI_NU ...

  10. Qt 学习之路 2(42):QListWidget、QTreeWidget 和 QTableWidget

    Qt 学习之路 2(42):QListWidget.QTreeWidget 和 QTableWidget 豆子 2013年2月5日 Qt 学习之路 2 38条评论 上一章我们了解了 model/vie ...