原创:POI读取excel转换成XML--V1.0

前期准备

-eclipse
-poi-3.16 jar包
-jdom-2.0.6 jar包
-xmlbeans-2.3.0 jar包

业务需要

测试系统时遇到一个小问题时,系统采用xml导入批量数据,且xml模板中存在一对一(a和b)和一对多(a和c)关系,同时在系统业务中,存在随机抽取的流程操作,xml模板导入的部分数据a需要从oracle中提取,本人通过excel模板编辑数据a和b,通过部分字段来控制变量便于测试,以下代码把excel转换成xml。

注意:这是本人第一次写导入excel代码,勿喷,欢迎交流
注意:本文仅适用于与c的数目相同的转换
注意:此代码只依据第一个listEnt来获取C对应的n(即item的数目)

EXCEL模板

此处忽略表头

读取的listEnt则是由A+B+C*n组成

代码

-引用的jar包

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellType;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;

-主代码

public class excelToXML {

    public static void main(String[] args) {
        //仅适用于一个三级产品目录一个产品分类,若存在多个产品分类,请转换成XML后手动增加
        try {
            excel2XML("D:\\18_FOR_TEST\\input.xlsx");// 读取excel的路径
            System.out.println("XML啦啦啦啦");
        } catch (IOException e) {
            e.printStackTrace();
            System.out.println("读取excel失败");
        }
    }

    @SuppressWarnings("resource")
    public static void excel2XML(String filename) throws IOException {
        InputStream input = new FileInputStream(filename);
        Workbook wb = new XSSFWorkbook(input);
        Sheet sheet = wb.getSheetAt(0); // 获得第一个表单
        int rowCount = sheet.getPhysicalNumberOfRows();// 获取总行数
        List<String> listEach = new ArrayList<String>();

        // 获取ItemNum并赋值
        int it = 0, itemNum = 0;
        for (int r = 0; r < rowCount; r++) {
            // 判断是否两行的数据是否相同
            if (r < 1)
                continue;
            if (sheet.getRow(r - 1).getCell(1).toString().equals(sheet.getRow(r).getCell(1).toSt
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值