使用jxl将excel行转列输出

写在前面的话:

最近工作时候领导让我们将如下样式的excel导入到库中

刚开始以为是正常的excel导入,结果仔细一看!!

字段是竖着的。正常的字段是横着的,结果这货给的数据是竖着的。

反人类了!所以我们称这个功能是:反人类。玩笑归玩笑但是

没办法领导让做的。只好做了。

下面是凯哥写的使用jxl将excel的行转列。

使用到的jar:

Code:

主要的实现方法:

/**

* excel 列转行

*

* @parma n 表示截断excel的多少列为一行 既是数据数量

*

*/

publicvoid rowcolumn(String inputfilename,String ouputfilename){

intn;

Workbook wb = null;

WritableSheet ws = null;

jxl.write.Label lable = null ;

WritableWorkbook wwb = null;

//大的第二行的插入行的起始位置

intstarth = 0;

intc=0;

try {

wb = Workbook.getWorkbook(new File(inputfilename));

} catch (Exception e) {

e.printStackTrace();

System.out.println(e);

}

if(null == wb){

return;

}

Sheet [] sheet = wb.getSheets();//获取工作表对象

if(null != sheet && sheet.length >0){

//创建第一个工作薄对象

try {

wwb = Workbook.createWorkbook(new File(ouputfilename));

if(null != wwb){

//创建一个可以写入的表。第一个是工作薄名、第二个是工作薄的位置

ws = wwb.createSheet("sheet1", 0);

}

} catch (Exception e) {

e.printStackTrace();

System.out.println(e);

}

for (inti = 0; i < sheet.length; i++) {//这里一般是由一个sheet的

intrownum = sheet[i].getRows();//工作薄对象的行数

intcolumn = sheet[i].getColumns();

System.out.println(rownum +" , "+column);

n = rownum+1;

for (intj = 0; j < column; j++) {

//得到当前行的所有单元格

Cell [] cell = sheet[i].getColumn(j);

System.out.println("cell:"+cell);

if(null != cell && cell.length>0){

//写入excel文件的行数

inthang = (j+1)*(((rownum-1)/rownum+1));

//插入位置应该接着上次插入的最后一行的下一行开始

for (intk = starth; k <hang; k++) {

//写入文件的行数

for (intk2 = 0; k2 < n; k2++) {

if(0 == k2){

lable = new jxl.write.Label(k2,k,cell[0].getContents());

}else{

c++;

if(c >= cell.length){

lable = new jxl.write.Label(k2, k, "");

c = 0;

}else{

lable = new jxl.write.Label(k2,k, cell[c].getContents());

System.out.println("----" + cell[c].getContents());

}

}

try {

ws.addCell(lable);//添加到excel

} catch (Exception e) {

System.out.println(e);

}

}

}

starth = hang;//把最后一行号赋值给第二个大行的插入位置

System.out.println("start>>>"+starth);

}

}

}

}

try {

wwb.write();//写入excel文件

wwb.close();

} catch (Exception e) {

System.out.println(e);

}

}



测试方法:

package com.kaigejava.poi;

import java.io.File;

import jxl.Cell;

import jxl.Sheet;

import jxl.Workbook;

import jxl.write.WritableSheet;

import jxl.write.WritableWorkbook;

/**

*

* @author 凯哥java 反人类的excel导入。竖着导入excel

*

*/

publicclass AnthumanPoiTest {

publicstaticvoid main(String[] args) {

AnthumanPoiTest ap = new AnthumanPoiTest();

ap.rowcolumn("C:\\Users\\凯哥java\\Desktop\\凯哥javat1.xls", "C:\\Users\\凯哥java\\Desktop\\凯哥javat1转换后的.xls");

}

}



运行结果:

运行前:

运行后:

ps:

如果您感觉本篇对您有帮助,请您动动手转发分享给您的好友。谢谢!

欢迎关注微信公众号:【凯哥java】

开心一刻;

1:

青年向大师哭诉:“大师,我高考失利,考不上大学,父母责骂我,女朋友也离我而去,请您收下我,让我皈依佛门吧!”只见大师拿出一叠高考资料,青年恍然大悟:“大师是叫我不要放弃高考,明年再战,是吗?”大师摇头说道:“施主,我们这里只招本科以上,你还是先回去考上本科再过来面试吧!”

2:

最近买了电子烟,使用感觉还不错。昨天出门坐公交随手就塞到牛仔裤兜里了,可能是牛仔裤太紧,压到开关了,整个车厢的人都看我胯下部位一直在冒烟,我还专心看手机根本没发觉,直到一个好心的哥们拍拍我,哥们你好像屌炸了。

3:

小时候,我妈不止一次跟我说,亲嘴会怀孕,亲嘴会怀孕,结果我家猫跳起来抢肉吃的时候好死不死亲到了我的嘴,过了几个月它还生下了三只小猫""出于责任感,有我一口肉吃,我就不会让那三只小猫吃素!

4:

都说女儿找了男朋友,父母会有自己辛辛苦苦种的白菜被猪拱了的伤感。可我弟弟自从找了女朋友,连家里都不回来住了,天天岳母娘给做好吃的,各种的乐不思蜀啊。老妈45°角仰望天空说:“白菜有没有拱着不知道,反正养了20多年的猪肯定是丢了。。。 ”



相关文章

Java输出语句三种实现方法

Java中常用的输出语句实现方法有以下三种:1.System.out.println():该方法可以将括号中的内容输出到控制台,并在结尾自动添加一个换行符。例如上述代码将输出字符串 "Hello Wo...

HTML+JavaSpringBoot输出内容的代码备存

仅仅是之前收集的代码备存,后续在展开代码思路:1、HTML构建一个form表单2、form表单里面动态填充需要输出的内容3、然后form表单submit提交4、ctrl层(后台)捕获内容并根据数据要求...

nohup后台启动项目,日志输出教程

1.jar包启动: [root@localhost data]# nohup java -jar ***.jar >nohup.log 2>&1 &启动之后,会在jar所在目录生成一个nu...

java如何生成动态Word文件

一、需求:你们项目中,是否有这么一个需求,用户在你的应用页面中,选择填充一堆数据,然后点击确定生成,系统会因你填充的数据而生成一份对应的Word文档。比如下图是一个word文档,打开后是这样的内容,使...

java日常开发必备:list的四种遍历

在平时的开发过程中使用List的场景很多,你知道List的遍历有多少种方式?今天一起来梳理下List的几种遍历方式。这里以java.util.ArrayList为例来演示。这里有一个最简单的测试类,里...