java进行xls转xml

一般用java语言来做excel表格的解析有两种常用的方法,poi或者jxl,

有关poi的使用可以参考点击打开链接

下面是用jxl解析excel文档,并输出到xml文件中,注释在代码中


package com.breeze.test;

import java.io.File;
import java.io.FileOutputStream;

import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;

import org.jdom2.Document;
import org.jdom2.Element;
import org.jdom2.output.XMLOutputter;

public class Excel2xml

{

	public static void main(String[] args)

	{
		Excel2xml e = new Excel2xml();
		e.ret();
	}

	public void ret() {

		jxl.Workbook readwb = null;

		try

		{
			// 构建Workbook对象, 只读Workbook对象

			// 直接从本地文件创建Workbook,将test.xls放在工程根目录下

			readwb = Workbook.getWorkbook(new File("test.xls"));
			// 创建根节点

			Element roots = new Element("root");
			// 根节点添加到文档中;
			Document doc = new Document(roots);
			
			//循环输出每个sheet到一个xml中
			for (int m = 0; m < readwb.getNumberOfSheets(); m++) {
				Sheet readsheet = readwb.getSheet(0);

				// 获取Sheet表中所包含的总列数

				int rsColumns = readsheet.getColumns();

				// 获取Sheet表中所包含的总行数

				int rsRows = readsheet.getRows();

				// 创建sheet根节点
				Element root = new Element("sheet"+m);

				//对每行分别解析
				for (int i = 0; i < rsRows; i++)

				{

					// 创建节点 sub;
					Element elements = new Element("sub");
					//解析每列
					for (int j = 0; j < rsColumns; j++)

					{
						//取出每个单元格
						Cell cell = readsheet.getCell(j, i);
						if (cell.getContents() == "") {
							continue;
						}
						elements.addContent("\n");
						elements.addContent("\t");
						elements.addContent("\t");
						elements.addContent("\t");
						Element element = new Element("cell");
						//设置节点的属性,同时处理回车换行
						if (cell.getContents().contains("\r\n")) {
							element.setAttribute("value", " ");
						} else {
							element.setAttribute("value", cell.getContents());
						}
						elements.addContent(element);
					}
					elements.addContent("\n");
					elements.addContent("\t");
					elements.addContent("\t");
					root.addContent("\n");
					root.addContent("\t");
					root.addContent("\t");
					root.addContent(elements);

				}
				root.addContent("\n");
				root.addContent("\t");
				roots.addContent("\n");
				roots.addContent("\t");
				roots.addContent(root);
			}
			roots.addContent("\n");
			XMLOutputter XMLOut = new XMLOutputter();

			// 输出data.xml 文件;
			XMLOut.output(doc, new FileOutputStream("data.xml"));

		} catch (Exception e) {

			e.printStackTrace();

		} finally {

			readwb.close();

		}
	}
}


这里是jxl的最新包下载http://www.andykhan.com/jexcelapi/download.html 

jdom的相关下载可以到这里去http://www.jdom.org/downloads/index.html

Java可以通过使用Apache POI库来实现将xls文件换为xlsx文件。 首先,我们需要在Java项目中引入Apache POI的相关依赖项。在maven项目中,可以在pom.xml文件中添加以下依赖项: ``` <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>4.1.2</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>4.1.2</version> </dependency> ``` 接下来,我们可以使用以下代码来实现将xls文件换为xlsx文件: ```java import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; public class ExcelConverter { public static void main(String[] args) { String inputFile = "input.xls"; // 输入的xls文件路径 String outputFile = "output.xlsx"; // 输出的xlsx文件路径 try { FileInputStream inputStream = new FileInputStream(inputFile); Workbook inputWorkbook = new HSSFWorkbook(inputStream); // 创建xls工作簿 Workbook outputWorkbook = new XSSFWorkbook(); // 创建xlsx工作簿 int numberOfSheets = inputWorkbook.getNumberOfSheets(); // 获取xls中的工作表数量 for (int i = 0; i < numberOfSheets; i++) { Sheet inputSheet = inputWorkbook.getSheetAt(i); // 获取xls中的一个工作表 Sheet outputSheet = outputWorkbook.createSheet(inputSheet.getSheetName()); // 创建对应的工作表到xlsx文件中 int rowCount = inputSheet.getLastRowNum(); for (int j = 0; j <= rowCount; j++) { Row inputRow = inputSheet.getRow(j); // 获取xls中的一行数据 Row outputRow = outputSheet.createRow(j); // 创建对应的行到xlsx文件中 int cellCount = inputRow.getLastCellNum(); for (int k = 0; k < cellCount; k++) { Cell inputCell = inputRow.getCell(k); // 获取xls中的一个单元格 Cell outputCell = outputRow.createCell(k); // 创建对应的单元格到xlsx文件中 outputCell.setCellValue(inputCell.getStringCellValue()); // 将xls单元格的值复制到xlsx单元格 } } } FileOutputStream outputStream = new FileOutputStream(outputFile); outputWorkbook.write(outputStream); // 将xlsx工作簿保存到文件中 outputStream.close(); inputWorkbook.close(); outputWorkbook.close(); System.out.println("换成功!"); } catch (IOException e) { e.printStackTrace(); } } } ``` 以上代码将读取名为"input.xls"的xls文件,将其内容复制到一个新创建的名为"output.xlsx"的xlsx文件中。换完成后,控制台将输出"换成功!"。 这就是使用Javaxls文件换为xlsx文件的基本步骤。你可以根据需要进行进一步的定制和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值