JAVA xml文件读取写入数据

文章目录

前言

对于少量数据或配置信息,可通过xml文件进行管理。xml可以运用标签实现类似数据库一样的数据管理。一些配置信息,比如文件保存路径,如果将这些配置写入yml文件后读不到的话,也可以试着写入xml文件。

代码

		<!--导入依赖-->
        <dependency>
            <groupId>org.dom4j</groupId>
            <artifactId>dom4j</artifactId>
            <version>2.1.3</version>
        </dependency>

public class XmlUtil {

	// xml文件名
    private static String xmlFileName = "pmp测试题答题情况记录.xml";

    public static boolean createXmlFile(Map<String,String> dataMap){
    	/**
    	* dataMap 为写入xml的数据,key为标签名,value为实际值
    	*/
        XMLWriter writer = null;
        try {
            // 生成一个Document对象
            Document doc = DocumentHelper.createDocument();
            // 添加根元素 pmpAnswerRecord可替换为其他名称
            Element root = doc.addElement("pmpAnswerRecord");
            // 为根元素添加子元素
                // 二级根元素名称 alreadyAnswer可替换为其他名称
                Element rootSecond = root.addElement("alreadyAnswer");
                Set key = dataMap.keySet();
                for (Object k : key) {
                    rootSecond.addElement(k.toString()).setText(String.valueOf(dataMap.get(k)));
                }

            // 输出xml文件
            OutputFormat format = OutputFormat.createPrettyPrint();
            writer = new XMLWriter(new OutputStreamWriter(new FileOutputStream(xmlFileName),"UTF-8"),format);
            writer.write(doc);
            return true;
        } catch (IOException e) {
            e.printStackTrace();
            return false;
        }finally {
            // 关闭资源
            try {
                if (writer != null) {
                    writer.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

	/**
	* 读取xml文件数据
	* 读取时跳过第一级和第二级目录
	*/
    public static Map<String,String> readXmlFile(){
        File file = new File(xmlFileName);
        if (!file.exists()) {
            return null;
        }
        try {
            Map<String,String> resMap = new HashMap<>();
            SAXReader reader = new SAXReader();
            Document dc = reader.read(file);
            //获取根节点
            Element rootElement = dc.getRootElement();
            Iterator<Element> iterator = rootElement.elementIterator();
            while (iterator.hasNext()) {
                Element book = iterator.next();
                Iterator<Element> elementIterator = book.elementIterator();
                while (elementIterator.hasNext()) {
                    Element next = elementIterator.next();
                    resMap.put(next.getName(),next.getText());
                }

            }
            return resMap;
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }
}

xml文件

<?xml version="1.0" encoding="UTF-8"?>

<pmpAnswerRecord>
  <alreadyAnswer>
    <falseNumber>9</falseNumber>
    <trueNumber>15</trueNumber>
    <questionNumber>25</questionNumber>
  </alreadyAnswer>
</pmpAnswerRecord>

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将 XML 文件的内容写入数据库,你可以使用编程语言中提供的 XML 解析库和数据库连接库来完成。以下是一个通用的步骤: 1. 使用适当的编程语言(如Python、Java、或Ruby)选择一个 XML 解析库和数据库连接库。这些库通常提供了从 XML 文件中提取数据和将数据插入数据库的方法和函数。 2. 使用选定的 XML 解析库读取 XML 文件并解析其内容。你可以使用适当的方法来遍历 XML 数据结构,并提取需要的数据。 3. 使用数据库连接库连接到你的数据库,并创建一个新的数据库表,该表的列应与 XML 文件中的数据结构相对应。你可以使用适当的方法来执行 SQL 语句来创建表。 4. 使用数据库连接库将数据插入到数据库表中。你可以使用适当的方法来执行 SQL 语句将数据插入到数据库中。 以下是一个使用 Python 的示例代码,使用 `xml.etree.ElementTree` 解析 XML 并将数据写入 MySQL 数据库: ```python import xml.etree.ElementTree as ET import mysql.connector # 解析XML文件 tree = ET.parse('path/to/your/xml/file.xml') root = tree.getroot() # 连接到MySQL数据库 conn = mysql.connector.connect( host="your_host", user="your_username", password="your_password", database="your_database" ) # 创建一个新表 cursor = conn.cursor() cursor.execute("CREATE TABLE IF NOT EXISTS your_table_name (column1 datatype, column2 datatype, ...)") # 插入数据 for child in root: data = [child.find('field1').text, child.find('field2').text, ...] # 根据XML的结构提取数据 sql = "INSERT INTO your_table_name (column1, column2, ...) VALUES (%s, %s, ...)" cursor.execute(sql, data) # 提交更改并关闭连接 conn.commit() conn.close() ``` 确保将 `'path/to/your/xml/file.xml'` 替换为实际的 XML 文件路径,`your_host`、`your_username`、`your_password` 和 `your_database` 分别替换为你的 MySQL 主机、用户名、密码和数据库名称,以及根据 XML 的结构和需要的字段进行调整。 根据你选择的编程语言和库,代码实现可能会有所不同,但基本的思路是解析 XML 文件并将数据插入到数据库中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值