Java实现csv文件转xml

一、需求

        从csv文件读取内容,写入到xml文件中去

二、实现

        第一步先从csv读取内容

        第二步把读取的内容写到xml

       注意:读取csv文件的内容是利用的hutool框架,所以要在pom文件加入依赖

        

<dependency>
     <groupId>cn.hutool</groupId>
     <artifactId>hutool-all</artifactId>
     <version>4.1.19</version>
</dependency>

代码如下:

    

package com.lsl.mylsl.controller;

import cn.hutool.core.io.FileUtil;
import cn.hutool.core.text.csv.CsvData;
import cn.hutool.core.text.csv.CsvReader;
import cn.hutool.core.text.csv.CsvRow;
import cn.hutool.core.text.csv.CsvUtil;
import cn.hutool.core.util.CharsetUtil;
import com.lsl.mylsl.module.Student;
import org.w3c.dom.Document;
import org.w3c.dom.Element;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import java.io.File;
import java.util.ArrayList;
import java.util.List;

public class MyTest {



    public static void main(String[] args) {

        List<Student> studentList = readCsv();
        createXml(studentList);

    }

    /**
     * 利用hutool框架读取csv文件内容到list
     */
    public static List<Student> readCsv() {
        CsvReader reader = CsvUtil.getReader();
        //从文件中读取CSV数据
        CsvData data = reader.read(FileUtil.file("C:\\Users\\perfe\\Desktop\\list.csv"), CharsetUtil.CHARSET_GBK);
        List<CsvRow> rows = data.getRows();

        for (CsvRow row : rows) {
            List<String> rawList = row.getRawList();
            System.out.println(rawList);
        }
        //csv文件的列依次是id,stuName,age,addr
        List<Student> studentList = new ArrayList<>();
        for (int i = 1; i < rows.size(); i++) {
            CsvRow row = rows.get(i);
            Student stu = new Student();
            List<String> rawList = row.getRawList();
            stu.setId(Integer.valueOf(rawList.get(0)));
            stu.setStuName(rawList.get(1));
            stu.setAge(Integer.valueOf(rawList.get(2)));
            stu.setAddr(rawList.get(3));
            studentList.add(stu);
        }

        System.out.println(studentList);
        return studentList;
    }


    /**
     * 创建xml并写入从csv读取的内容
     * @param studentList
     */
    public static void createXml(List<Student> studentList){
        try {
            // 创建解析器工厂
            DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
            DocumentBuilder db = factory.newDocumentBuilder();
            Document document = db.newDocument();
            // 不显示standalone="no"
            document.setXmlStandalone(true);
            Element students = document.createElement("students");

            for (Student stu : studentList){
                Element student = document.createElement("student");
                student.setAttribute("flag", "true");

                Element id = document.createElement("id");
                id.setTextContent(stu.getId()+"");
                student.appendChild(id);

                Element name = document.createElement("name");
                name.setTextContent(stu.getStuName());
                student.appendChild(name);

                Element age = document.createElement("age");
                age.setTextContent(stu.getAge()+"");
                student.appendChild(age);

                Element addr = document.createElement("addr");
                addr.setTextContent(stu.getAddr());
                student.appendChild(addr);

                students.appendChild(student);

            }

            // 将students节点(已包含student)添加到dom树中
            document.appendChild(students);

            // 创建TransformerFactory对象
            TransformerFactory tff = TransformerFactory.newInstance();
            // 创建 Transformer对象
            Transformer tf = tff.newTransformer();

            // 输出内容是否使用换行
            tf.setOutputProperty(OutputKeys.INDENT, "yes");
            // 创建xml文件并写入内容
            tf.transform(new DOMSource(document), new StreamResult(new File("D:\\Download\\students.xml")));
            System.out.println("生成student.xml成功");
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("生成student.xml失败");
        }
    }




//    public static void filter(List<String> list){
//
//        for (int m=list.size()-1;m==0;m--){
//            if (!"a".equals(list.get(m))){
//                list.remove(m);
//            }
//        }
//
//    }
//
//    public byte[] blobToByte(Blob blob) throws Exception {
//        byte[] bytes = null;
//        try {
//            InputStream in=blob.getBinaryStream();
//            BufferedInputStream inBuffered = new BufferedInputStream(in);
//            ByteArrayOutputStream out = new ByteArrayOutputStream(1024);
//            byte[] temp = new byte[1024];
//            int size = 0;
//            while ((size = inBuffered.read(temp)) != -1) {
//                out.write(temp, 0, size);
//            }
//            inBuffered.close();
//            in.close();
//            bytes = out.toByteArray();
//        } catch(Exception ex){
//            ex.printStackTrace();
//        }
//        return bytes;
//    }

}

生成截图如下:

 

以下是一个简单的Java程序,可以将CSV文件换为XML文件: ```java import java.io.BufferedReader; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; public class CsvToXmlConverter { public static void main(String[] args) { String csvFile = "input.csv"; // 输入CSV文件 String xmlFile = "output.xml"; // 输出XML文件 BufferedReader br = null; String line = ""; String cvsSplitBy = ","; try (FileWriter fw = new FileWriter(xmlFile)) { fw.write("<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"); fw.write("<data>\n"); br = new BufferedReader(new FileReader(csvFile)); while ((line = br.readLine()) != null) { String[] data = line.split(cvsSplitBy); fw.write(" <record>\n"); fw.write(" <field1>" + data[0] + "</field1>\n"); fw.write(" <field2>" + data[1] + "</field2>\n"); fw.write(" <field3>" + data[2] + "</field3>\n"); fw.write(" </record>\n"); } fw.write("</data>\n"); System.out.println("XML file created successfully!"); } catch (IOException e) { e.printStackTrace(); } finally { if (br != null) { try { br.close(); } catch (IOException e) { e.printStackTrace(); } } } } } ``` 在这个示例中,我们假设输入文件是`input.csv`,输出文件是`output.xml`。程序将逐行读取CSV文件,将每一行拆分为字段,并将其写入XML文件。在本示例中,我们将CSV文件中的每一行换为一个XML记录,并将每个字段换为XML元素。XML文件的结构如下所示: ```xml <?xml version="1.0" encoding="UTF-8"?> <data> <record> <field1>value1</field1> <field2>value2</field2> <field3>value3</field3> </record> <record> <field1>value4</field1> <field2>value5</field2> <field3>value6</field3> </record> ... </data> ``` 你可以根据自己的需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一路奔跑1314

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值