`

java poi excel 操作类 支持2003,2007

阅读更多
原文转自: http://www.ij2ee.com/2011/05/05/java-poi-excel-%E6%93%8D%E4%BD%9C%E7%B1%BB-%E6%94%AF%E6%8C%812003%EF%BC%8C2007.html
package com.oow.util;

 

import java.io.File;

import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.InputStream;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

 

import org.apache.log4j.Logger;

import org.apache.poi.hssf.usermodel.HSSFCell;

import org.apache.poi.hssf.usermodel.HSSFFont;

import org.apache.poi.hssf.usermodel.HSSFFooter;

import org.apache.poi.hssf.usermodel.HSSFHeader;

import org.apache.poi.hssf.usermodel.HSSFRow;

import org.apache.poi.hssf.usermodel.HSSFSheet;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import org.apache.poi.hssf.usermodel.contrib.HSSFCellUtil;

import org.apache.poi.ss.usermodel.CellStyle;

import org.apache.poi.ss.usermodel.Font;

import org.apache.poi.ss.usermodel.contrib.CellUtil;

import org.apache.poi.ss.util.CellRangeAddress;

import org.apache.poi.xssf.usermodel.XSSFCell;

import org.apache.poi.xssf.usermodel.XSSFRow;

import org.apache.poi.xssf.usermodel.XSSFSheet;

import org.apache.poi.xssf.usermodel.XSSFWorkbook;

 

/**

 * @author Jeson

 * @blog:http://www.ij2ee.com

 * @date:2011-5-4 下午01:20:17

 * @version :1.0

 * 

 */

public class ExcelUtil2 {

 

    public static int maxRowSize = 60000;

 

    public static void main(String[] args) throws Exception {

String excelPath = "D:/test.xlsx";

// testReadExcel(excelPath);

// testCreateExcel(excelPath);

testData2Excel(excelPath);

// testReadFrom2007(excelPath);

    }

 

    private static void testData2Excel(String excelPath) {

List a = new ArrayList();

Object[] os = new Object[2];

os[0] = 1;

os[1] = 2;

a.add(os);

a.add(os);

a.add(os);

a.add(os);

a.add(os);

a.add(os);

Object[] tt = new Object[2];

tt[0] = "tt1";

tt[1] = "tt2";

data2Excel2007(a, tt, excelPath);

 

    }

 

    private static void testReadFrom2007(String filePath) throws Exception {

Map map = parseFromFile(filePath);

Object tts[] = map.keySet().toArray();

for (Object tt : tts) {

   System.out.println("title -> " + tt);

   Object o = map.get(tt);

   List list = (List) o;

   for (Object os : list) {

List os1 = (ArrayList) os;

for (Object o1 : os1) {

   System.out.print(o1);

}

System.out.println();

   }

}

    }

 

    private static void testCreateExcel(String excelPath) throws IOException {

createExcel(excelPath);

HSSFWorkbook book = new HSSFWorkbook();

// setBorder(book,1,1,1,1);

 

HSSFSheet sheet = createSheet(book, "工作空间1");

sheet.setDisplayGridlines(true);

setSheetHeadAndFoot(sheet);

for (int i = 0; i < 100; i++) {

   HSSFRow row = createRow(sheet, i, null);

 

   for (int j = 0; j < 2; j++) {

System.out.print(j + "" + i);

 

HSSFCell cell = row.createCell(j);

cell.setCellValue(i + "" + j);

   }

   System.out.println();

}

 

// cs.setb

writeWorkbook(book, excelPath);

 

    }

 

    /**

     * 将数据导出到excel

     * 

     * @param datas

     *            数据 list型的

     * @param titles

     *            将作为excel的title 可以为null

     * @param filePath

     *            文件路径

     * @return

     * @throws FileNotFoundException

     */

    public static boolean data2Excel(List<Object> datas, Object[] titles,

   String filePath) throws FileNotFoundException {

boolean is2003 = is2003(filePath);

if (is2003) {

   data2Excel2003(datas, titles, filePath);

} else {

   data2Excel2007(datas, titles, filePath);

}

return true;

    }

 

    private static void data2Excel2007(List<Object> datas, Object[] titles,

   String filePath) {

XSSFWorkbook book = new XSSFWorkbook();

int allDataSize = datas.size();

double pageNum_ = Integer.valueOf(allDataSize).doubleValue()

/ Integer.valueOf(maxRowSize).doubleValue();

double sheetSize = Math.ceil(pageNum_);

// setBorder(book, 100, 100, 100, 100);

for (int i = 0; i < sheetSize; i++) {

   XSSFSheet sheet = book.createSheet("Sheet" + i);

   for (int j = 0; j < datas.size(); j++) {

XSSFRow row = sheet.createRow(j);

Object data = datas.get(j);

Object os[] = (Object[]) data;

for (int k = 0; k < os.length; k++) {

   XSSFCell xcell = row.createCell(k);

   xcell.setCellValue(os[k] + "");

}

   }

}

writeWorkbook2007(book, filePath);

    }

 

    private static void data2Excel2003(List<Object> datas, Object[] titles,

   String filePath) {

HSSFWorkbook book = new HSSFWorkbook();

int allDataSize = datas.size();

double pageNum_ = Integer.valueOf(allDataSize).doubleValue()

/ Integer.valueOf(maxRowSize).doubleValue();

double sheetSize = Math.ceil(pageNum_);

// setBorder(book, 100, 100, 100, 100);

for (int i = 0; i < sheetSize; i++) {

   HSSFSheet sheet = createSheet(book, "Sheet" + i);

   sheet.setDisplayGridlines(true);

   if (titles != null) {

HSSFRow row = createRow(sheet, 0, null);

int ttSize = titles.length;

for (int j = 0; j < ttSize; j++) {

   CellUtil.createCell(row, j, titles[j] + "");

 

}

for (int l = 0; l < datas.size(); l++) {

   Object data = datas.get(l);

   Object[] os = (Object[]) data;

   HSSFRow rowl = createRow(sheet, l + 1, null);

   Object[] d = (Object[]) data;

   for (int j = 0; j < d.length; j++) {

CellUtil.createCell(rowl, j, d[j] + "");

 

   }

}

   } else {

for (int l = 0; l < datas.size(); l++) {

   Object data = datas.get(l);

   Object[] os = (Object[]) data;

   HSSFRow row = createRow(sheet, l, null);

   Object[] d = (Object[]) data;

   for (int j = 0; j < d.length; j++) {

HSSFCellUtil.createCell(row, j, d[j] + "");

 

   }

}

   }

   writeWorkbook(book, filePath);

}

    }

 

    private static boolean is2003(String filePath) throws FileNotFoundException {

File file = new File(filePath);

if (!file.exists() || !file.isFile()) {

   throw new FileNotFoundException();

}

int len = filePath.length();

String su = filePath.substring(len – 5, len);

if (su.indexOf("xlsx") != -1) {

   return false;

} else if (su.indexOf("xls") != -1) {

   return true;

}

return false;

    }

 

    public static Map parseFromFile(String filePath) throws Exception {

boolean is2003 = is2003(filePath);

File file = new File(filePath);

return is2003 ? extractTextFromXLS(new FileInputStream(file))

: extractTextFromXLS2007(file);

    }

 

    public static Map extractTextFromXLS(InputStream inputStream)

   throws IOException {

Map context = new HashMap();

HSSFWorkbook hssfWorkbook = new HSSFWorkbook(inputStream);

HSSFSheet hssfSheet = null;

List list_1 = null;

List list_2 = null;

HSSFRow hssfRow = null;

HSSFCell hssfCell = null;

for (int i = 0; i < hssfWorkbook.getNumberOfSheets(); ++i) {

   hssfSheet = hssfWorkbook.getSheetAt(i);

   if (null == hssfSheet) {

break;

   }

   list_1 = new ArrayList();

   for (int j = 0; j <= hssfSheet.getLastRowNum(); ++j) {

hssfRow = hssfSheet.getRow(j);

if (null == hssfRow) {

   list_1.add(null);

} else {

   list_2 = new ArrayList();

   for (int k = 0; k < hssfRow.getLastCellNum(); ++k) {

hssfCell = hssfRow.getCell(k);

if (null == hssfCell) {

   list_2.add(null);

} else if (hssfCell.getCellType() == 0) {

   list_2.add(Double.valueOf(

   hssfCell.getNumericCellValue()).toString());

} else if (hssfCell.getCellType() == 4) {

   list_2.add(Boolean.valueOf(

   hssfCell.getBooleanCellValue()).toString());

} else {

   list_2.add(hssfCell.getStringCellValue());

}

   }

   list_1.add(list_2);

}

   }

   context.put(hssfSheet.getSheetName(), list_1);

}

return context;

    }

 

    public static Map extractTextFromXLS2007(File paramFile) throws Exception {

return extractTextFromXLS2007(paramFile.getPath());

    }

 

    public static Map extractTextFromXLS2007(String filePath) throws Exception {

Map context = new HashMap();

System.out.println(" === " + filePath + " === ");

XSSFWorkbook xssfWorkbook = new XSSFWorkbook(filePath);

List list_1 = null;

List list_2 = null;

XSSFSheet xssfSheet = null;

for (int i = 0; i < xssfWorkbook.getNumberOfSheets(); ++i) {

   xssfSheet = xssfWorkbook.getSheetAt(i);

   if (xssfSheet == null) {

break;

   }

   list_1 = new ArrayList();

   for (int j = 0; j <= xssfSheet.getLastRowNum(); ++j) {

XSSFRow xssfRow = xssfSheet.getRow(j);

if (null == xssfRow) {

   list_1.add(null);

} else {

   list_2 = new ArrayList();

   for (int k = 0; k < xssfRow.getLastCellNum(); ++k) {

XSSFCell xssfCell = xssfRow.getCell(k);

if (null == xssfCell) {

   list_2.add(null);

} else if (xssfCell.getCellType() == 4) {

   list_2.add(Boolean.valueOf(

   xssfCell.getBooleanCellValue()).toString());

} else if (xssfCell.getCellType() == 0) {

   list_2.add(Double.valueOf(

   xssfCell.getNumericCellValue()).toString());

} else {

   list_2.add(xssfCell.getStringCellValue());

}

   }

   list_1.add(list_2);

}

   }

   System.out.println("xSheet is " + xssfSheet.getSheetName());

   context.put(xssfSheet.getSheetName(), list_1);

}

return context;

    }

 

    /**

     * 

     * 功能:将HSSFWorkbook写入Excel文件

     * 

     * @param wb

     *            HSSFWorkbook

     * 

     * @param absPath

     *            写入文件的相对路径

     * 

     * @param wbName

     *            文件名

     */

    public static void writeWorkbook(HSSFWorkbook wb, String fileName) {

FileOutputStream fos = null;

try {

   fos = new FileOutputStream(fileName);

   wb.write(fos);

} catch (FileNotFoundException e) {

   log.error(new StringBuffer("[").append(e.getMessage()).append("]")

   .append(e.getCause()));

} catch (IOException e) {

   log.error(new StringBuffer("[").append(e.getMessage()).append("]")

   .append(e.getCause()));

} finally {

   try {

if (fos != null) {

   fos.close();

}

   } catch (IOException e) {

log.error(new StringBuffer("[").append(e.getMessage()).append(

"]").append(e.getCause()));

   }

}

    }

 

    /**

     * 

     * 功能:将XSSFWorkbook写入Excel文件

     * 

     * @param wb

     *            HSSFWorkbook

     * 

     * @param absPath

     *            写入文件的相对路径

     * 

     * @param wbName

     *            文件名

     */

    public static void writeWorkbook2007(XSSFWorkbook wb, String fileName) {

FileOutputStream fos = null;

try {

   fos = new FileOutputStream(fileName);

   wb.write(fos);

} catch (FileNotFoundException e) {

   log.error(new StringBuffer("[").append(e.getMessage()).append("]")

   .append(e.getCause()));

} catch (IOException e) {

   log.error(new StringBuffer("[").append(e.getMessage()).append("]")

   .append(e.getCause()));

} finally {

   try {

if (fos != null) {

   fos.close();

}

   } catch (IOException e) {

log.error(new StringBuffer("[").append(e.getMessage()).append(

"]").append(e.getCause()));

   }

}

    }

 

    /**

     * 

     * 功能:创建HSSFSheet工作簿

     * 

     * @param wb

     *            HSSFWorkbook

     * 

     * @param sheetName

     *            String

     * 

     * @return HSSFSheet

     */

    public static HSSFSheet createSheet(HSSFWorkbook wb, String sheetName) {

HSSFSheet sheet = wb.createSheet(sheetName);

sheet.setDefaultColumnWidth(12);

sheet.setGridsPrinted(false);

sheet.setDisplayGridlines(false);

return sheet;

    }

 

    /**

     * 

     * 功能:创建HSSFRow

     * 

     * @param sheet

     *            HSSFSheet

     * 

     * @param rowNum

     *            int

     * 

     * @param height

     *            int

     * 

     * @return HSSFRow

     */

    public static HSSFRow createRow(HSSFSheet sheet, int rowNum, Integer height) {

HSSFRow row = sheet.createRow(rowNum);

if (height != null) {

 

   row.setHeight(Short.parseShort(height.toString()));

}

return row;

    }

 

    /**

     * 

     * 功能:创建CellStyle样式

     * 

     * @param wb

     *            HSSFWorkbook

     * 

     * @param backgroundColor

     *            背景色

     * 

     * @param foregroundColor

     *            前置色

     * 

     * @param font

     *            字体

     * 

     * @return CellStyle

     */

    public static CellStyle createCellStyle(HSSFWorkbook wb,

   short backgroundColor, short foregroundColor, short halign,

   Font font) {

CellStyle cs = wb.createCellStyle();

cs.setAlignment(halign);

cs.setVerticalAlignment(CellStyle.VERTICAL_CENTER);

cs.setFillBackgroundColor(backgroundColor);

cs.setFillForegroundColor(foregroundColor);

cs.setFillPattern(CellStyle.SOLID_FOREGROUND);

cs.setFont(font);

return cs;

    }

 

    /**

     * 

     * 功能:创建带边框的CellStyle样式

     * 

     * @param wb

     *            HSSFWorkbook

     * 

     * @param backgroundColor

     *            背景色

     * 

     * @param foregroundColor

     *            前置色

     * 

     * @param font

     *            字体

     * 

     * @return CellStyle
 [color=white] 原文转自: http://www.ij2ee.com/2011/05/05/java-poi-excel-%E6%93%8D%E4%BD%9C%E7%B1%BB-%E6%94%AF%E6%8C%812003%EF%BC%8C2007.html[/color]
     */

    public static CellStyle createBorderCellStyle(HSSFWorkbook wb,

   short backgroundColor, short foregroundColor, short halign,

   Font font) {

CellStyle cs = wb.createCellStyle();

cs.setAlignment(halign);

cs.setVerticalAlignment(CellStyle.VERTICAL_CENTER);

cs.setFillBackgroundColor(backgroundColor);

cs.setFillForegroundColor(foregroundColor);

cs.setFillPattern(CellStyle.SOLID_FOREGROUND);

cs.setFont(font);

cs.setBorderLeft(CellStyle.BORDER_DASHED);

cs.setBorderRight(CellStyle.BORDER_DASHED);

cs.setBorderTop(CellStyle.BORDER_DASHED);

cs.setBorderBottom(CellStyle.BORDER_DASHED);

return cs;

    }

 

    public static void setBorder(HSSFWorkbook book, Integer top,

   Integer bottom, Integer left, Integer right) {

CellStyle style = book.createCellStyle();

if (top != null) {

   style.setBorderTop(Short.parseShort(top.toString()));

}

if (bottom != null) {

   style.setBorderBottom(Short.parseShort(bottom.toString()));

}

if (left != null) {

   style.setBorderLeft(Short.parseShort(left.toString()));

}

if (right != null) {

   style.setBorderRight(Short.parseShort(right.toString()));

}

 

    }

 

    /**

     * 

     * 功能:创建CELL

     * 

     * @param row

     *            HSSFRow

     * 

     * @param cellNum

     *            int

     * 

     * @param style

     *            HSSFStyle

     * 

     * @return HSSFCell

     */

    public static HSSFCell createCell(HSSFRow row, int cellNum, CellStyle style) {

HSSFCell cell = row.createCell(cellNum);

cell.setCellStyle(style);

return cell;

    }

 

    /**

     * 

     * 功能:合并单元格

     * 

     * @param sheet

     *            HSSFSheet

     * 

     * @param firstRow

     *            int

     * 

     * @param lastRow

     *            int

     * 

     * @param firstColumn

     *            int

     * 

     * @param lastColumn

     *            int

     * 

     * @return int 合并区域号码

     */

    public static int mergeCell(HSSFSheet sheet, int firstRow, int lastRow,

   int firstColumn, int lastColumn) {

return sheet.addMergedRegion(new CellRangeAddress(firstRow, lastRow,

firstColumn, lastColumn));

    }

 

    /**

     * 

     * 功能:创建字体

     * 

     * @param wb

     *            HSSFWorkbook

     * 

     * @param boldweight

     *            short

     * 

     * @param color

     *            short

     * 

     * @return Font

     */

    public static Font createFont(HSSFWorkbook wb, short boldweight,

   short color, short size) {

Font font = wb.createFont();

font.setBoldweight(boldweight);

font.setColor(color);

font.setFontHeightInPoints(size);

return font;

    }

 

    /**

     * 

     * 设置合并单元格的边框样式

     * 

     * @param sheet

     *            HSSFSheet

     * 

     * @param ca

     *            CellRangAddress

     * 

     * @param style

     *            CellStyle

     */

    public static void setRegionStyle(HSSFSheet sheet, CellRangeAddress ca,

   CellStyle style) {

for (int i = ca.getFirstRow(); i <= ca.getLastRow(); i++) {

   HSSFRow row = HSSFCellUtil.getRow(i, sheet);

   for (int j = ca.getFirstColumn(); j <= ca.getLastColumn(); j++) {

HSSFCell cell = HSSFCellUtil.getCell(row, j);

cell.setCellStyle(style);

   }

}

    }

 

    public static Font setFont(HSSFWorkbook workbook, int fontHeight,

   short boldWeight) {

// 字体

HSSFFont font = workbook.createFont();

// Font font = workbook.createFont();

font.setFontName("宋体");

font.setFontHeightInPoints((short) fontHeight);

font.setBoldweight(boldWeight);

return font;

    }

 

    public static boolean createExcel(String path) throws IOException {

File f = new File(path);

if (!f.exists()) {

   f.createNewFile();

   return true;

} else

   return true;

    }

 

    public static void setSheetHeadAndFoot(HSSFSheet sheet) {

HSSFHeader header = sheet.getHeader();

header.setCenter("Center Header");

header.setLeft("Left Header");

header.setRight(HSSFHeader.font("Stencil-Normal", "Italic")

+ HSSFHeader.fontSize((short) 16)

+ "Right w/ Stencil-Normal Italic font and size 16");

 

HSSFFooter footer = (HSSFFooter) sheet.getFooter();

footer.setRight("Page " + HSSFFooter.page() + " of "

+ HSSFFooter.numPages());

    }

 

    private static Logger log = Logger.getLogger(ExcelUtil2.class);

}
分享到:
评论

相关推荐

    java poi excel 操作类 支持2003,2007版本

    java poi excel 操作类 支持2003,2007版本 java poi excel 操作类 支持2003,2007版本 你也可以直接访问本文: ...

    基于POI的Excel操作Java类

    为更方便的使用POI的API来操作Excel(2003)文件,对POI中针对Excel文件的读写进行了简单封装。此类中包含以下功能: 1.根据模板创建Excel文件 ...压缩包中包含POI的jar文件、POIExcel的jar文件及POIExcel的源码

    java使用POI操作excel (支持excel2007)

    Java 使用Apache POI库操作Excel 2007文件详解 在Java开发中,处理Excel文件是一项常见的任务,特别是对于数据分析、数据导入导出或报表生成等场景。Apache POI是一个流行的开源库,它允许开发者读写Microsoft ...

    java_poi实现excel导入导出

    5. 使用 Java POI 实现 Excel 导入导出工具类 在上面的示例中,我们已经实现了 Excel 导入和导出功能。下面是一个实现了 Excel 导入导出工具类的示例: ```java import org.apache.poi.hssf.usermodel.HSSFWorkbook...

    Java Poi 操作excel的API 好用

    Java POI项目由Apache软件基金会维护,支持读取和写入Microsoft Office的多种文件格式,如XLS(Excel 97-2003)、XLSX(Excel 2007以上版本)以及Word、PowerPoint等。对于Excel,POI提供了一个高级用户模型(HSSF)...

    java poi操作excel小例子

    Java POI 操作 Excel 是一个常见的任务,在许多业务场景中都需要用到,比如数据导入导出、数据分析等。Apache POI 是一个流行的开源库,它允许开发者使用 Java 来读写 Microsoft Office 格式的文件,其中包括 Excel ...

    java的poi生成excel图表demo

    POI库不仅支持基本的文本和数字操作,还支持更高级的功能,如公式计算、样式设置和图表创建。 2. **创建Excel图表** 要生成Excel图表,我们需要先创建一个`XSSFWorkbook`对象,这代表了整个Excel工作簿。接着,创建...

    java_poi导入excel通用工具类

    这个"java_poi导入excel通用工具类"是利用Java的POI库和一些额外的技术来实现对Excel数据的导入功能,使得开发人员能够方便地将Excel数据转化为Java对象或者对已有对象进行填充。下面我们将深入探讨相关的知识点。 ...

    java中poi读写excel封装工具类(兼容office2003和2007等版本)

    它不仅支持旧版的Excel文件格式(.xls,用于Office 2003及更早版本),还支持新版本的Excel文件格式(.xlsx,自Office 2007起)。以下是对"java中poi读写excel封装工具类"这一主题的详细解释。 1. **Apache POI介绍...

    java poi excel 模板导入通用工具类,支持2003/2007

    3. **版本兼容**:由于支持2003和2007两种版本的Excel,工具类内部可能使用了POI的不同API来处理不同格式的文件。HSSF是处理`.xls`(2003及更早版本)的API,而XSSF则是处理`.xlsx`(2007及更高版本)的API。 4. **...

    poi 操作excel模板

    在Java开发中,POI库被广泛用于生成、修改和读取Excel文档。本篇将深入探讨如何利用Apache POI来操作Excel模板,以及如何读取数据并将其填充到新生成的文件中,最终提供下载。 首先,你需要在项目中引入Apache POI...

    java poi操作excel批量导入导出项目需要的jar包

    Java中的Apache POI库是处理Microsoft Office文档的强大工具,尤其在Excel操作方面。它允许开发者在Java应用程序中创建、修改和读取Excel文件。在进行批量导入和导出Excel数据时,Apache POI是一个非常实用的选择。...

    java POI Excel操作

    在进行Excel操作时,需要捕获并处理可能抛出的异常,如`IOException`、`NullPointerException`等。 综上所述,Java POI 提供了丰富的功能,用于在Java应用程序中进行Excel的导入和导出。通过理解这些基本概念和方法...

    java 通过poi操作excel jar包

    在实际使用中,Java开发者首先需要将对应的JAR包添加到项目的类路径中,然后就可以通过调用Apache POI提供的API来实现Excel操作。例如,创建一个新的Excel文件并写入数据的简单示例代码: ```java import org....

    Java POI 导出Excel 2007 实例源代码

    在Java开发中,如果需要生成或操作Excel文件,Java POI是一个强大的工具。本实例将重点介绍如何使用Java POI来导出Excel 2007(xlsx格式)文件。 一、Java POI简介 Java POI项目始于2001年,由Apache软件基金会维护...

    java_poi导入excel通用工具类V0915

    "java_poi导入excel通用工具类V0915" 提供了一种通用的方式来处理Excel数据的导入工作,它支持多种赋值方式,包括单个对象、列表对象以及指定坐标的赋值。 首先,让我们深入理解一下这个工具类的主要功能: 1. **...

    poi excel poi excel poi excel

    HSSF 提供了一系列的类来操作 Excel 文件: - **HSSFWorkbook**:表示整个工作簿,即一个 Excel 文件。 - **HSSFSheet**:表示工作簿中的一个工作表。 - **HSSFRow**:表示工作表中的一行。 - **HSSFCell**:表示...

    java使用poi在excel单元格添加超链接,设置字体颜色(csdn)————程序.pdf

    在Java开发中,Apache POI库是一个非常实用的工具,用于读取、写入和修改Microsoft Office格式的文件,特别是Excel。本篇文章主要探讨如何利用POI在Excel单元格中添加超链接,并设置字体颜色。 首先,为了使用...

    (实例)java poi完美解决excel2003和2007、2010之间兼容问题

    在Java世界中,当需要处理Excel数据时,POI库是一个常用的选择,尤其在需要跨版本兼容性时,如在Excel 2003、2007和2010之间。以下将详细讲解如何使用Java POI来完美解决这些版本之间的兼容问题。 首先,Excel 2003...

    java操作excel支持2003-2007

    总之,Java通过Apache POI库提供了强大的Excel操作能力,无论是2003年的.xls格式还是2007年的.xlsx格式,都能进行有效的读写和处理。在实际项目中,应根据需求选择合适的API,注意性能优化,以实现高效、稳定的数据...

Global site tag (gtag.js) - Google Analytics