`
rentianchou
  • 浏览: 69652 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

POI解析Excel

阅读更多

我要解析如附件中的Excel 格式代码并生成xml文件,具体格式见附件图片

package readexceltoxml;

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.io.UnsupportedEncodingException;
import java.util.ArrayList;
import java.util.List;

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.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;

public class Test {

	/**
	 * @param args
	 */
	public static void main(String[] args)throws Exception {
		// TODO Auto-generated method stub
		String zh_big_postion = null;
		String en_big_postion = null;
		String filepath = "d:/a.xls";
		List<String> zh_value = new ArrayList<String> ();    //中文值
		List<String> en_value = new ArrayList<String> ();    //英文值
		boolean b = false;
		
		//String last
		
		InputStream is = new FileInputStream(filepath);
		HSSFWorkbook book = new HSSFWorkbook(is);
		HSSFSheet sheet = book.getSheet("职位类别");
		int rows = sheet.getPhysicalNumberOfRows();//获得总行数
		
		
		
		for(int i=0;i<rows;i++){//循环每行
			
			HSSFRow row = sheet.getRow(i);
			
			HSSFCell A = row.getCell(0);
			HSSFCell B = row.getCell(1);
			HSSFCell C = row.getCell(2);
			HSSFCell D = row.getCell(3);
			
			String a_value = A.getStringCellValue();
			String b_value = B.getStringCellValue();
			String c_value = C.getStringCellValue();
			String d_value = D.getStringCellValue();
			if(!"".equals(a_value)){
				zh_big_postion = a_value;
			}
			if(!"".equals(b_value)){
				en_big_postion = b_value;
			}
			if(i==0){
				zh_value.add(c_value);
				en_value.add(d_value);
			}else if(i!=0&&"".equals(a_value)){
				zh_value.add(c_value);
				en_value.add(d_value);
			}
			
				HSSFRow roww = sheet.getRow(i+1);
				if(roww!=null){              //如果下一行第一列有值就是true
					HSSFCell AA = roww.getCell(0);
					String aa_value = AA.getStringCellValue();
					if(!"".equals(aa_value))
						b = true;
				}
				
			
			
			
			if(b||i==rows-1){//如果为true或者是最后一行就写入到xml里
				Document document = generXML(zh_big_postion, en_big_postion,
						zh_value, en_value);
				
				writeHtml("d:/position.xml",document);
				
				
				zh_big_postion = null;
				en_big_postion = null;
				zh_value.clear();
				en_value.clear();
				b = false;
			}
		}

		is.close();
		System.out.println("end");
	}

	/**
	 * 生成xml文件
	 * @param zh_big_postion
	 * @param en_big_postion
	 * @param zh_value
	 * @param en_value
	 * @return
	 * @throws DocumentException
	 */
	private static Document generXML(String zh_big_postion,
			String en_big_postion, List<String> zh_value, List<String> en_value)
			throws DocumentException {
		SAXReader reader = new SAXReader();
		Document document = reader.read(new File("d:/position.xml"));
		Element root = document.getRootElement(); //获得根节点
		
		Element position_zh = DocumentHelper.createElement("position-zh");
		Element position_en = DocumentHelper.createElement("position-en");
		
		Element name_zh = DocumentHelper.createElement("name");
		name_zh.addText(zh_big_postion);
		Element name_en = DocumentHelper.createElement("name");
		name_en.addText(en_big_postion);
		
		position_zh.add(name_zh);
		position_en.add(name_en);
		
		Element position_small_zh = DocumentHelper.createElement("position-small");
		Element position_small_en = DocumentHelper.createElement("position-small");
		
		for(String value:zh_value){
			Element name = DocumentHelper.createElement("name");
			name.addText(value);
			position_small_zh.add(name);
		}
		position_zh.add(position_small_zh);
		
		for(String value:en_value){
			Element name = DocumentHelper.createElement("name");
			name.addText(value);
			position_small_en.add(name);
		}
		position_en.add(position_small_en);
		
		root.add(position_zh);
		root.add(position_en);
		return document;
	}

	/**
	 * 写到xml文件里
	 * @param path
	 * @param d
	 */
	private static void writeHtml(String path, Document d) {
		FileOutputStream fos = null;
		try {
			fos = new FileOutputStream(path);
		} catch (FileNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}    
        OutputFormat of=new OutputFormat("",true);   
        of.setEncoding("UTF-8");

        XMLWriter xw = null;
		try {
			xw = new XMLWriter(fos, of);
			 xw.write( d );    
		     xw.close();
		} catch (UnsupportedEncodingException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			if(fos!=null){
				try {
					fos.close();
				} catch (IOException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}
			if(xw!=null){
				try {
					xw.close();
				} catch (IOException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}
		}
	}
	
}
生成的xml文件如附件中

 

  • 大小: 207.6 KB
  • 大小: 72.2 KB
分享到:
评论

相关推荐

    使用POI解析excel文件并写入数据库

    使用poi解析excel文件,并将数据写入到数据库 项目说明 这个项目实现的功能是读取excel文件中的数据,解析并写入数据库。 读取的excel文件位于项目目录下的 excel\0805.xlsx 使用IntelliJ IDEA开发此项目 使用MYSQL...

    Java Poi 解析EXCEL数据

    以上就是使用Java Poi解析Excel数据的基本流程。在实际应用中,你可能还需要处理其他复杂场景,比如样式、公式、超链接等。Poi库提供了丰富的API来处理这些问题,使得与Excel文件的交互变得简单且灵活。在提供的"poi...

    利用POI解析excel并存入数据库demo

    在这个"利用POI解析excel并存入数据库demo"中,我们将关注如何使用 POI 库来读取 Excel 文件,并将数据有效地存入 MySQL 数据库。 首先,要开始使用 POI,你需要在你的项目中引入相应的依赖。如果你使用的是 Maven...

    poi解析excel文件

    标题提到的"poi解析excel文件"是利用Apache POI 3.8版本进行Excel数据的读取和解析。 在Apache POI 3.8中,主要涉及以下核心概念: 1. **HSSF(Horrible Spreadsheet Format)**:这是Apache POI中处理旧版Excel...

    POI解析EXCEl分层

    标题“POI解析EXCEL分层”涉及到的主要知识点是Apache POI库在处理Microsoft Excel文件时的层次化数据解析。Apache POI是一个流行的开源Java API,它允许开发者读取、写入和修改Microsoft Office格式的文件,其中...

    poi 解析excel文件内容demo

    在这个"poi 解析excel文件内容demo"中,我们主要关注如何使用Apache POI库来读取和解析Excel文件,无论它们是2003版的.XLS还是2007以后的.XLSX格式。 首先,Apache POI提供了两种主要的接口来处理Excel文件:HSSF...

    poi解析excel

    【标题】"poi解析excel"涉及的是Java编程中使用Apache POI库来处理Microsoft Excel文件的知识。Apache POI是开源项目,提供了API用于读写Microsoft Office格式的文件,特别是Excel。在Java应用中,POI使得开发者能够...

    poi解析excel的poi包

    以上就是使用Apache POI解析Excel文件并将数据存入Oracle数据库的基本步骤。在实际应用中,你可能需要根据具体需求进行调整,例如处理不同类型的单元格(数字、日期等)、异常处理、优化性能等。

    POI解析Excel简单实例

    POI解析Excel简单实例

    apache poi解析Excel时报错,我将Excel打开后保存,就不会报错,用jar完美解决

    apache poi解析Excel时报错,我将Excel打开后保存,就不会报错,我将重写的类从新打包这样问题虽然网上有解决方案,但是需要自己打包重写对应类,我已将这些步骤做好了。

    POI解析excel并存入mysqlのdemo

    这个“POI解析excel并存入mysqlのdemo”是利用 Java 的 Apache POI 库来读取 Excel 数据,并将这些数据存储到 MySQL 数据库中的示例。下面我们将详细探讨相关的知识点。 1. **Apache POI**: Apache POI 是一个...

    poi 解析excel实例

    在描述中提到的“ poi解析excel的工具类”,通常包含了一些常用的方法,例如打开文件、读取单元格数据、处理合并单元格等。以下是一些可能包含在该工具类中的关键方法: 1. **打开文件**:使用`WorkbookFactory`类...

    POI解析Excel文档

    【标题】"POI解析Excel文档"涉及到的主要技术是Apache POI库,它是一个用于读取和写入Microsoft Office格式档案的开源Java API。在Java编程环境中,使用POI库可以方便地处理Excel(.xlsx和.xls)文件,进行数据的...

    poi解析Excel所需要的包

    在Java环境中,使用Apache POI库解析Excel文件时,确实需要引入一系列的依赖包来确保所有必要的功能得以正常运行。这些包包含了对Excel文件格式的理解和支持,允许开发者读取、写入和修改Excel数据。 1. **Apache ...

    poi解析excel2007

    最新版poi解析excel2007源码,简单实用,需要的可下.

    通过poi解析Excel示例

    本示例将深入讲解如何使用Apache POI来解析Excel文件。 Apache POI是Apache软件基金会的一个开源项目,它的主要功能是处理微软的Office Open XML (OOXML) 和早期的二进制文件格式,例如Excel的.BIFF8格式。在Java中...

    使用poi解析Excel

    《使用POI解析Excel》 在信息技术领域,处理数据是日常工作中不可或缺的一部分,而Excel作为广泛使用的电子表格软件,其数据处理能力强大且灵活。Apache POI是一个开源库,专门用于读取和写入Microsoft Office格式...

    POI解析excel

    在本文中,我们将深入探讨如何使用POI解析Excel 2013和2017版本的文件,并将结果转换为List集合。 一、Apache POI简介 Apache POI是Apache软件基金会的一个开源项目,它提供了API来读取、写入和修改Microsoft ...

Global site tag (gtag.js) - Google Analytics