使用jxl读取excel内容,并转换成Json,用于Datagrid
一、上传excel文件,得到InputStream,由InputStream得到Jxl中的Workbook,取出内容,存到二维数组中。
1、使用 Jquery Uploadify 插件(http://www.uploadify.com/ ),得到FileItem,由FileItem得到InputStream。
- String[][] excelContent = getExcelContent(fileItem.getInputStream());
2、将Excel内容存放到二维数组中。
- public String[][] getExcelContent(InputStream is) {
- try {
- Workbook workBook = Workbook.getWorkbook(is);
- Sheet sheet = workBook.getSheet(0);
- int sheetColumns = sheet.getColumns();
- int sheetRows = sheet.getRows();
- // excel内容
- String[][] excelContent = new String[sheetRows][sheetColumns];
- for (int i = 0; i < sheetRows; i++) {
- for (int j = 0; j < sheetColumns; j++) {
- // 将excel值放入二维数组excelContent中
- excelContent[i][j] = sheet.getCell(j, i).getContents();
- }
- }
二、将二维数组转换成JSON(stringBuffer)格式为:[{"filed1":,"value"},{"filed2":,"value2"}]
- stringBuffer = convertToJson(excelContent);
拼字符串花了我很多时间
- private static final String QUOTATION_MARKS = "\""; //双引号
- private static final String COMMA = ","; //逗号
- public StringBuffer convertToJson(String[][] srcArray) {
- StringBuffer stringBuffer = new StringBuffer();
- boolean first = true;
- stringBuffer.append("[");
- for (int i = 0; i < srcArray.length; i++) {
- String[] arrayItem = srcArray[i];
- if (!first) {
- stringBuffer.append(COMMA);
- }
- stringBuffer.append("{");
- boolean first2 = true;
- for (int j = 0; j < arrayItem.length; j++) {
- if (!first2) {
- stringBuffer.append(COMMA);
- }
- stringBuffer.append(QUOTATION_MARKS + "field" + j
- + QUOTATION_MARKS + ":\"" + arrayItem[j]
- + QUOTATION_MARKS);
- first2 = false;
- }
- stringBuffer.append("}");
- first = false;
- }
- stringBuffer.append("]");
- return stringBuffer;
- }
三、生成可用于DataGrid加载的Json格式,即 {"total":n,"rows":[{"filed1":,"value"},{"filed2":,"value2"}]}。
- sheetRows = excelContent.length;
- sheetColumns = excelContent[0].length;
- StringBuffer stringBuffer2 = new StringBuffer("");
- stringBuffer2.append("{");
- stringBuffer2.append(QUOTATION_MARKS + "total"
- + QUOTATION_MARKS + ":" + sheetRows + COMMA
- + QUOTATION_MARKS + "rows" + QUOTATION_MARKS + ":");
- stringBuffer2.append(stringBuffer);
- stringBuffer2.append("}");
http://bbs.csdn.net/topics/390395096
使用jxl读取excel内容,并转换成Json,用于Datagrid的更多相关文章
- 分享一个小工具:Excel表高速转换成JSON字符串
在游戏项目中一般都须要由策划制作大量的游戏内容,当中非常大一部分是使用Excel表来制作的.于是程序就须要把Excel文件转换成程序方便读取的格式. 之前项目使用的Excel表导入工具都是通过Offi ...
- JAVA利用jxl读取Excel内容
JAVA可以利用jxl简单快速的读取文件的内容,但是由于版本限制,只能读取97-03 xls格式的Excel. import java.io.File; import java.io.FileInp ...
- C#读取数据库内容并转换成xml文件
OleDbConnection conn = new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\bi ...
- C# Excel转换成Json工具(含源码)
可执行版本下载:https://github.com/neil3d/excel2json/releases 完整项目源代码下载:https://github.com/neil3d/excel2json ...
- python如何转换word格式、读取word内容、转成html
# python如何转换word格式.读取word内容.转成html? import docx from win32com import client as wc # 首先将doc转换成docx wo ...
- 【游戏开发】Excel表格批量转换成lua的转表工具
一.简介 在上篇博客<[游戏开发]Excel表格批量转换成CSV的小工具> 中,我们介绍了如何将策划提供的Excel表格转换为轻便的CSV文件供开发人员使用.实际在Unity开发中,很多游 ...
- EasyExcel 轻松灵活读取Excel内容
写在前面 Java 后端程序员应该会遇到读取 Excel 信息到 DB 等相关需求,脑海中可能突然间想起 Apache POI 这个技术解决方案,但是当 Excel 的数据量非常大的时候,你也许发现, ...
- POI读取Excel内容格式化
在用POI读取Excel内容时,经常会遇到数据格式化的问题. 比如:数字12365会变为12365.0;字符串数字123也会变为123.0,甚至会被变为科学计数法.另外日期格式化也是一个头疼的问题.其 ...
- C# 读取Excel内容
一.方法 1.OleD方法实现该功能. 2.本次随笔内容只包含读取Excel内容,并另存为. 二.代码 (1)找到文档代码 OpenFileDialog openFile = new OpenFile ...
随机推荐
- touchmove和touchend的使用
touchstart:当手指触摸屏幕时触发:即使已经有一个手指放在了屏幕上也会触发.touchmove:当手指在屏幕上滑动时连续的触发.在这个事件发生期间,调用preventDefault()可阻止滚 ...
- URLRewrite 实现方法详解
所谓的伪静态页面,就是指的URL重写,在ASP.NET中实现非常简单首先你要在你的项目里引用两个DLL:ActionlessForm.dll.URLRewriter.dll,真正实现重写的是 URLR ...
- asp.net微信内置浏览器下Session失效
问题记录:仅限安卓端微信内置浏览器,服务器集群设置了黏性Session,在Post请求时会强制走代理,导致出去的ip指向另一台服务器,黏性Session失效,用户状态无法保存. 目前想知道除了设置Se ...
- VINS-Mono Installation
Prerequisites 1.1 ** Ubuntu 16.04, ROS Kinetic ** sudo apt-get install ros-kinetic-cv-bridge ros-kin ...
- kali linux之主动信息收集(三层发现,四层发现)
三层发现: 比二层发现的优点即可路由,就是速度比二层慢,相对我们来说还是算快的,经常被边界防火墙过滤 ip icmp协议 OSI七层模型
- SpringBoot Maven多模块整合MyBatis 打包jar
最近公司开始新的项目,框架选定为SpringBoot+Mybatis,本篇主要记录了在IDEA中搭建SpringBoot多模块项目的过程. 源码:https://github.com/12641561 ...
- CentOS71611部署Django
web.conf <VirtualHost *:> WSGIScriptAlias / /var/www/datacn/datacn/wsgi.py Alias /static/ /var ...
- upsource代码审查
upsource 从零搭建代码审查平台,需要的不仅是把代码审查的工具搭起来,还要结合公司情况制定一系列的代码审查规范.下面是对选择的upsource web端代码审查工具的安装及介绍.详细的请看这篇文 ...
- 查看db连接数sql
/****** Object: StoredProcedure [dbo].[SP_Conn] Script Date: 12/09/2018 19:03:28 ******/ SET ANSI_NU ...
- Qt 学习之路 2(42):QListWidget、QTreeWidget 和 QTableWidget
Qt 学习之路 2(42):QListWidget.QTreeWidget 和 QTableWidget 豆子 2013年2月5日 Qt 学习之路 2 38条评论 上一章我们了解了 model/vie ...