网站首页 > java教程 正文
写在前面的话:
最近工作时候领导让我们将如下样式的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多年的猪肯定是丢了。。。 ”
猜你喜欢
- 2024-11-17 「开源资讯」MyExcel 3.3.0.GA 发布,终于支持图片导入啦
- 2024-11-17 如何优雅的用POI导入Excel文件
- 2024-11-17 EasyExcel 优雅实现 Excel 导入导出
- 2024-11-17 Spring Boot框架下实现Excel服务端导入导出
- 2024-11-17 Java 设置Excel工作表的视图模式
- 2024-11-17 在Java中,如何以编程的方式设置 Excel 单元格样式
- 2024-11-17 Java 将Excel工作表中的图表转换为图片
- 2024-11-17 Java 查找、替换并高亮Excel数据
- 2024-11-17 相见恨晚,用阿里 EasyExcel 优雅实现导入导出功能
- 2024-11-17 Java实现文件批量导入导出实践(兼容xls,xlsx)
你 发表评论:
欢迎- 最近发表
-
- 你真的会用 Java 中的线程池吗?多个企业级线程池工具类封装实践
- 线程池的实现原理、优点与风险、以及四种线程池实现
- Java线程池ThreadPoolExecutor实现原理剖析
- 深入分析线程池的实现原理(线程池是干嘛的)
- 一文搞懂JAVA线程池工作原理(java线程池的工作流程)
- Java线程池的工作原理(java线程池的实现原理)
- 5分钟读懂C#中TcpClient、TcpListener和Socket三个类的角色
- JVM对象的创建过程(jvm运行过程中创建的对象一般存放在方法区)
- 对象组成与Java内存模型JMM分析(java对象在内存中存储的结构)
- JVM对象内存分配详细过程(栈上分配->TLAB->老年代->Eden区)
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)