把Excel文件中的数据直接读取之后写到XML文件中

要用到的jar包:

dom4j-1.6.1.jar

poi-3.2-FINAL-20081019.jar

poi-contrib-3.2-FINAL-20081019.jar

poi-scratchpad-3.2-FINAL-20081019.jar


以下是java源代码


import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.FileWriter;

import java.io.IOException;



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

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

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

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

import org.dom4j.Document;

import org.dom4j.DocumentHelper;

import org.dom4j.Element;

import org.dom4j.io.OutputFormat;

import org.dom4j.io.XMLWriter;



public class ExcelXMLTest {



/**

* @param args

*/

public static void main(String[] args) {

export("D:/code.xls","D:/Area.xml");

}



public static void export(String inFile,String outFile){



HSSFWorkbook book = null;

try {

//读取一个现有的excel文件

book = new HSSFWorkbook(new FileInputStream(inFile));

} catch (FileNotFoundException e) {

System.out.println("===要读取的excel文件不存在===");

e.printStackTrace();

} catch (IOException e) {

System.out.println("===读取excel文件是出错===");

e.printStackTrace();

}

//获取excel文件的第一个工作薄

HSSFSheet sheet = book.getSheetAt(0);

//创建一个XML的文件

Document d = DocumentHelper.createDocument();

//为这个XML文件设置一个根结点,名为:address

Element root = d.addElement("address");

//获取的代码

String code = "";

//代码对应的值

String value = "";

//省级代码,也就是代码的前两位,如北京:11

String proCode = "";

//市级代码,也就是代码的前四位,如北京1100

String cityCode = "";

//创建几个结点,省级结点

Element province = null;

//市级结点

Element city = null;

//乡镇结点

Element country = null;

//循环读取excel文件中的数据,第一行是标题就不读取了

for(int i=1;i<sheet.getLastRowNum();i++) {

HSSFRow row = sheet.getRow(i);

HSSFCell codeCell = row.getCell(0);

HSSFCell valueCell = row.getCell(1);

code = new String((int)codeCell.getNumericCellValue()+"");

if(valueCell.getRichStringCellValue()!=null)

value = valueCell.getRichStringCellValue().toString();



//如果省级代码不等于代码中的前两位就表示这又是另一个省了

if(!proCode.equals(code.substring(0,2))) {

//改变省级代码

proCode = code.substring(0,2);

//在根目录下添加一个province的子结点

province = root.addElement("province");

//为这个结点添加一两个属性:name和value,对应的值两个是value和code

province.addAttribute("name", value);

province.addAttribute("value", code);

//如果市级代码不等于代码的前四位就表示这是另一个市的了

} else if(!cityCode.equals(code.substring(0,4))) {

//改变市级代码

cityCode = code.substring(0,4);

//在省结点下添加相应的市子结点

city = province.addElement("city");

//设置两个属性并赋值

city.addAttribute("name", value);

city.addAttribute("value", code);

} else {

//否则的话就直接在市结点下添加相应的乡镇子结点

country = city.addElement("country");

country.addAttribute("name", value);

country.addAttribute("value", code);

}

}



try {

//格式化XML

OutputFormat format = OutputFormat.createPrettyPrint();

//是否缩进

format.setIndent(true);

//在声明完之后是否进行换行

format.setNewLineAfterDeclaration(false);

//设置字符编码,只是在声明里把encoding的值设置为UTF-8

format.setEncoding("UTF-8");

//进否格式化

format.setTrimText(true);

//进否添加新行

format.setNewlines(true);

XMLWriter writer = new XMLWriter(new FileWriter(outFile),format);

writer.write(d);

//写完之后要进行flush这样才会把数据真正的写到文件中去

writer.flush();

writer.close();

System.out.println("===成功生成XML文件!!!===");

} catch (IOException e) {

System.out.println("===生成XML文件是出错===");

e.printStackTrace();

}



}



}

相应包及源代码:http://bbs.fengfly.com/thread-129-1-1.html
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值