合并多个Excel工作簿,会出现电话号码以科学计数法显示,如果想要以字符串方式处理,要按如下完整代码

    public static void mergeWorkBook() throws Exception  {

         long startTime = System.currentTimeMillis();    //获取开始时间
String fromPath = "exceldoc\\cases";// excel存放路径
String toPath = "exceldoc/result/";// 保存新EXCEL路径
// 新的excel 文件名
String excelName = "汇总";
// 创建新的excel
HSSFWorkbook wbCreat = new HSSFWorkbook();
File file = new File(fromPath);
for (File excel : file.listFiles()) {
// 打开已有的excel
String strExcelPath = fromPath + "/" + excel.getName();
// input 来源 ,output 目的地
InputStream in = new FileInputStream(strExcelPath);
HSSFWorkbook wb = new HSSFWorkbook(in);
//获取工作簿的名称,不带前缀
String bookName = excel.getName().substring(0,excel.getName().lastIndexOf("."));
// i表示源工作簿 sheet 数量
int sheetnum = wb.getNumberOfSheets();
for (int i = 0; i < sheetnum; i++) {
//开始每个表的处理
HSSFSheet sheet = wb.getSheetAt(i);
// 目标工作簿创建同样的sheet名
String sheetName = sheet.getSheetName(); int firstRow = sheet.getFirstRowNum();
int lastRow = sheet.getLastRowNum(); System.out.println("workbook:"+bookName);
System.out.println("sheetName:"+sheetName);
//如果sheet的lastrow 是0 表示这个表没有内容,这张sheet就不用处理,继续处理下张sheet处理,用continue
if(lastRow == 0 ){
continue;
} HSSFSheet sheetCreat = wbCreat.createSheet(bookName +"_"+ sheet.getSheetName()); //开始多行的处理
for (int j = firstRow; j <= lastRow ; j++) {
// 创建新建excel Sheet的行
HSSFRow rowCreat = sheetCreat.createRow(j);
// 取得源有excel Sheet的行
HSSFRow row = sheet.getRow(j);
// 单元格式样
//如果行的内容为null ,说明行为空行,此行就跳过,继续下行的处理,用continue
if(null == row){
continue;
}
System.out.println("bookName:"+bookName+"|sheetName:"+sheetName+"|row:"+j);
int lastCell = row.getLastCellNum();
int firstCell = row.getFirstCellNum();
for (int k = firstCell; k < lastCell && lastCell >0; k++) {
String strVal =""; if (null != row.getCell(k)) {
switch (row.getCell(k).getCellType()) {
case HSSFCell.CELL_TYPE_NUMERIC: // 数字 DecimalFormat df = new DecimalFormat("#"); strVal = df.format(row.getCell(k).getNumericCellValue()); break;
case HSSFCell.CELL_TYPE_STRING: // 字符串
strVal=row.getCell(k).getStringCellValue() + "";
break;
case HSSFCell.CELL_TYPE_BOOLEAN: // Boolean
strVal= row.getCell(k).getBooleanCellValue()+ "";
break;
case HSSFCell.CELL_TYPE_FORMULA: // 公式
strVal = row.getCell(k).getCellFormula() + "";
break;
case HSSFCell.CELL_TYPE_BLANK: // 空值
strVal = "";
break;
case HSSFCell.CELL_TYPE_ERROR: // 故障
System.out.println(i+ j + "CELL_TYPE_ERROR");
break;
default:
System.out.print(i+ j + "未知类型 ");
break;
}
//System.out.println(strVal);
rowCreat.createCell(k).setCellType(HSSFCell.CELL_TYPE_STRING);;
rowCreat.getCell(k).setCellValue(strVal+"");
}
}
System.out.println("单行处理完毕");
}
System.out.println("多行处理完毕");
}
System.out.println("多表处理完毕");
}
System.out.println("多个文件处理完毕");
System.out.println(toPath + excelName + ".xls");
FileOutputStream fileOut = new FileOutputStream(toPath + excelName + ".xls"); wbCreat.write(fileOut);
fileOut.close(); HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(toPath + excelName + ".xls"));
System.out.println( workbook.getNumberOfSheets()); long endTime = System.currentTimeMillis(); //获取结束时间 System.out.println("程序运行时间:" + (endTime - startTime) + "ms"); //输出程序运行时间 }

主要是要读源文件时要对单元格进行判断

 if (null != row.getCell(k)) {
switch (row.getCell(k).getCellType()) {
case HSSFCell.CELL_TYPE_NUMERIC: // 数字 DecimalFormat df = new DecimalFormat("#"); strVal = df.format(row.getCell(k).getNumericCellValue()); break;
case HSSFCell.CELL_TYPE_STRING: // 字符串
strVal=row.getCell(k).getStringCellValue() + "";
break;
case HSSFCell.CELL_TYPE_BOOLEAN: // Boolean
strVal= row.getCell(k).getBooleanCellValue()+ "";
break;
case HSSFCell.CELL_TYPE_FORMULA: // 公式
strVal = row.getCell(k).getCellFormula() + "";
break;
case HSSFCell.CELL_TYPE_BLANK: // 空值
strVal = "";
break;
case HSSFCell.CELL_TYPE_ERROR: // 故障
System.out.println(i+ j + "CELL_TYPE_ERROR");
break;
default:
System.out.print(i+ j + "未知类型 ");
break;
}
//System.out.println(strVal);
rowCreat.createCell(k).setCellType(HSSFCell.CELL_TYPE_STRING);;
rowCreat.getCell(k).setCellValue(strVal+"");
}

再在写之前进行写单元格处理:

rowCreat.createCell(k).setCellType(HSSFCell.CELL_TYPE_STRING);;

合并多个excel工作簿的更多相关文章

  1. 使用SPIRE.XLS来创建Excel 工作簿

               使用SPIRE.XLS来创建Excel 工作簿     概要 最近在研究 .NET 控件,使用这些控件在程序中可以快速低成本实现功能. 在这一篇中我们使用的控件是Spire.XL ...

  2. 把Excel工作簿的每个工作表提取出来保存为新工作簿

    平台:MS office 2010 任务:有个excel工作簿,其中有上百个工作表,要求把每一个工作表全部保存为新工作簿,如果一个一个复制出来太傻了,可以用excel自带的VB解决. 方法:打开工作簿 ...

  3. 如何使用 Visual C# 2005 或 Visual C# .NET 向 Excel 工作簿传输数据

    本文分步介绍了多种从 Microsoft Visual C# 2005 或 Microsoft Visual C# .NET 程序向 Microsoft Excel 2002 传输数据的方法.本文还提 ...

  4. [办公自动化]excel工作簿内的表无法删除,单击右键无删除键

    今天同事问,我自己的工作簿,没有设置保护,但是就是无法删除其中的工作表. 后来发现,她的excel工作簿打开的文件名后面显示[共享]. 原因找到了. 取消共享就可以了.

  5. 怎么拆分一个Excel工作簿中的多个工作表?

    打开需要编辑的Excel文档.如图所示,工作簿下方有很多工作表.现在需要将这些工作表单独拆分开成一个个工作簿.   右键任意一个工作表标签,在弹出的下拉列表中选择查看代码.即弹出代码窗口.如下图所示. ...

  6. 等Excel工作簿关闭后自动加密压缩备份

    ;; 等Excel工作簿关闭后自动加密压缩备份.ahk;; 腾讯QQ号 595076941; 作者:boai; 写作日期:2019年5月15日; 版本号:第1版; 手机号(中国移动) 138##### ...

  7. 等Excel工作簿关闭后自动加密压缩备份2019年10月9日.ahk

    ;; 等Excel工作簿关闭后自动加密压缩备份2019年10月9日.ahk;; 腾讯QQ号 595076941; 作者:徐晓亮(weiyunwps618); 写作日期:2019年5月15日; 版本号: ...

  8. excel-合并多个Excel文件--VBA合并当前目录下所有Excel工作簿中的所有工作表

    在网上找EXCEL多文件合并的方法,思路: 一.Linux 或者window+cmder,直接用命令行cat合并EXCEL文件,但是,需要安装辅助东西才能直接处理(也许也不可以,但是,可以用文件格式转 ...

  9. 如何解决excel工作簿保护密码

    自己的excel文档设置了“保护工作簿”密码,但是密码又忘记了,怎么办? 如果你会编写代码,那么这个问题非常好解决.Excel内置功能不能解决的事儿,自己编写一段代码或许就可以搞定了. 第一步,大家已 ...

随机推荐

  1. psp个人软件过程需求文档

    1.  业务需求 1.1 应用背景 开发软件项目进度计划总是那么不准确,延期经常出现,跟可恨的是甚至无法给出一个相对比较明确的延迟时间.很大 因素在于分配给开发人员的完成时间与开发人员的实际完成时间有 ...

  2. java总结文章

    java总结文章 原创地址: http://www.cnblogs.com/Alandre/ (泥沙砖瓦浆木匠),须要转载的,保留下! Thanks Talk is cheap. Show me th ...

  3. 在Centos 5.6下安装 redis

    先引用redis官方(http://redis.io/) 的介绍: Redis is an open source, advanced key-value store.<br>It is ...

  4. 函数返回char* 的解决方案

    在C语言中,自动变量在堆栈中分配内存.当包含自动变量的函数或代码块退出时,它们所占用的内存便被回收,它们的内容肯定会被下一个所调用的函数覆盖.这一切取决于堆栈中先前的自动变量位于何处,活动函数声明了什 ...

  5. Java可见性机制的原理

    基本概念 可见性 当一个线程修改了共享变量时,另一个线程可以读取到这个修改后的值. 内存屏障(Memory Barriers) 处理器的一组指令,用于实现对内存操作的顺序限制. 缓冲行 CPU告诉缓存 ...

  6. android离线下载的相关知识

    离线下载的功能点如下:      1.下载管理(开始.取消下载).      2.网络判断(Wi-Fi,3G).      3.独立进程.      4.定时和手机催醒.      5.自启动. 选择 ...

  7. 模拟jquery封装选择器

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. OD: Format String, SQL Injection, XSS

    Format String 格式化串漏洞 考虑如下的代码: #include<stdio.h> int main() { int a=44,b=77; printf("a=%d, ...

  9. java 线程池的用法

    1.java自带的类ExecutorService用于提供线程池服务,可以一下方法初始化线程池: ExecutorService pool = Executors.newFixedThreadPool ...

  10. Swift 语言函数

    import Foundation // 函数声明于实现 func sayHello(name){ print("Hello \(name)") } // 函数调用 sayHell ...