首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何使用Java代码将XML文件转换为CSV?

将XML文件转换为CSV文件可以通过Java代码实现。下面是一个示例代码:

代码语言:txt
复制
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

public class XMLtoCSVConverter {
    public static void main(String[] args) {
        String xmlFilePath = "input.xml";
        String csvFilePath = "output.csv";

        try {
            DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
            DocumentBuilder builder = factory.newDocumentBuilder();
            Document document = builder.parse(xmlFilePath);

            FileWriter csvWriter = new FileWriter(csvFilePath);

            NodeList nodeList = document.getDocumentElement().getChildNodes();
            for (int i = 0; i < nodeList.getLength(); i++) {
                Node node = nodeList.item(i);
                if (node.getNodeType() == Node.ELEMENT_NODE) {
                    Element element = (Element) node;
                    List<String> rowData = new ArrayList<>();
                    NodeList childNodes = element.getChildNodes();
                    for (int j = 0; j < childNodes.getLength(); j++) {
                        Node childNode = childNodes.item(j);
                        if (childNode.getNodeType() == Node.ELEMENT_NODE) {
                            rowData.add(childNode.getTextContent());
                        }
                    }
                    csvWriter.append(String.join(",", rowData));
                    csvWriter.append("\n");
                }
            }

            csvWriter.flush();
            csvWriter.close();

            System.out.println("XML to CSV conversion completed.");
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

这段代码使用Java的DOM解析器将XML文件解析为Document对象,然后遍历XML文件的元素,将每个元素的子元素的文本内容提取出来,并以CSV格式写入到输出文件中。

使用该代码,你需要将xmlFilePath变量设置为输入的XML文件路径,将csvFilePath变量设置为输出的CSV文件路径。运行代码后,将会在指定的输出文件中生成相应的CSV文件。

这种方法适用于XML文件结构相对简单的情况,如果XML文件结构复杂,可以根据实际情况进行适当的修改。

推荐的腾讯云相关产品:腾讯云云服务器(ECS)、腾讯云对象存储(COS)。

腾讯云云服务器(ECS):https://cloud.tencent.com/product/cvm

腾讯云对象存储(COS):https://cloud.tencent.com/product/cos

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

领券