java 创建与解析XML文件

newfilename 修改后另存为该文件
       * @return 返回操作结果, 0表失败, 1表成功
       */

      public int ModiXMLFile(String filename,String newfilename){
         int returnValue = 0;
         try{
             SAXReader saxReader = new SAXReader();
             Document document = saxReader.read(new File(filename));
             //Document document=saxReader.read(new StringReader(filename));
             /** 修改内容之一: 如果book节点中show属性的内容为yes,则修改成no */
             /** 先用xpath查找对象 */
             List list = document.selectNodes("/books/book/@show" );
             Iterator iter = list.iterator();
             while(iter.hasNext()){
                Attribute attribute = (Attribute)iter.next();
                if(attribute.getValue().equals("yes")){
                    attribute.setValue("no");
                }
             }
             /**
              * 修改内容之二: 把owner项内容改为Tshinghua
              * 并在owner节点中加入date节点,date节点的内容为2004-09-11,还为date节点添加一个属性type
              */
             list = document.selectNodes("/books/owner" );
             iter = list.iterator();
             if(iter.hasNext()){
                Element ownerElement = (Element)iter.next();
                ownerElement.setText("Tshinghua");
                Element dateElement = ownerElement.addElement("date");
                dateElement.setText("2007-09-06");
                dateElement.addAttribute("type","Gregorian calendar");
             }

             /** 修改内容之三: 若title内容为Dom4j Tutorials,则删除该节点 */

             list = document.selectNodes("/books/book");

             iter = list.iterator();

             while(iter.hasNext()){

                Element bookElement = (Element)iter.next();

                Iterator iterator = bookElement.elementIterator("title");

                 while(iterator.hasNext()){

                    Element titleElement=(Element)iterator.next();

                    if(titleElement.getText().equals("Dom4j Tutorials")){

                       bookElement.remove(titleElement);

                    }

                }

             }



             try{

                /** 将document中的内容写入文件中 */

                XMLWriter writer = new XMLWriter(new FileWriter(new File(newfilename)));

                writer.write(document);

                writer.close();

                /** 执行成功,需返回1 */

                returnValue = 1;

             }catch(Exception ex){

                ex.printStackTrace();

             }



         }catch(Exception ex){

             ex.printStackTrace();

         }

         return returnValue;

      }


      /**

         * 格式化XML文档,并解决中文问题

         * @param filename

         * @return

         */

        public int formatXMLFile(String filename){

           int returnValue = 0;

           try{

               SAXReader saxReader = new SAXReader();

               Document document = saxReader.read(new File(filename));

               XMLWriter writer = null;

               /** 格式化输出 */

               OutputFormat format = OutputFormat.createPrettyPrint();

               /** 指定XML编码 */

               format.setEncoding("GBK");

               writer= new XMLWriter(new FileWriter(new File(filename)),format);

               writer.write(document);

               writer.close();

               /** 执行成功,需返回1 */

               returnValue = 1;

           }catch(Exception ex){

               ex.printStackTrace();

           }

           return returnValue;

        }



    public static void main(String[] args) {

       Dom4jDemo temp = new Dom4jDemo();
       temp.createXMLFile("e://myxml.xml");
       //temp.formatXMLFile("e://myxml.xml");
       //temp.ModiXMLFile("e://myxml.xml", "e://myxml2.xml");

       //System.out.println(temp.createXMLFile("d://testxml.xml"));
      
       //System.out.println(temp.ModiXMLFile("d://testxml.xml","d://testxml2.xml"));
//       try{
         //System.out.println(temp.formatXMLFile("d://testxml2.xml"));
//        // System.out.println(temp.formatXMLFile("E:\\test.xml"));
//       }
//       catch(Exception e)
//       {
//        // e.printStackTrace();
//        System.out.print("error!");
//
//    }

    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 下面是 Java 解析 XML 文件的核心代码: ``` import java.io.File; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.NodeList; public class Main { public static void main(String[] args) { try { File xmlFile = new File("example.xml"); DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance(); DocumentBuilder dBuilder = dbFactory.newDocumentBuilder(); Document doc = dBuilder.parse(xmlFile); System.out.println("Root element :" + doc.getDocumentElement().getNodeName()); NodeList nList = doc.getElementsByTagName("student"); System.out.println("----------------------------"); for (int temp = 0; temp < nList.getLength(); temp++) { org.w3c.dom.Node nNode = nList.item(temp); System.out.println("\nCurrent Element :" + nNode.getNodeName()); if (nNode.getNodeType() == org.w3c.dom.Node.ELEMENT_NODE) { org.w3c.dom.Element eElement = (org.w3c.dom.Element) nNode; System.out.println("Student roll no : " + eElement.getAttribute("rollno")); System.out.println("First Name : " + eElement.getElementsByTagName("firstname").item(0).getTextContent()); System.out.println("Last Name : " + eElement.getElementsByTagName("lastname").item(0).getTextContent()); System.out.println("Nick Name : " + eElement.getElementsByTagName("nickname").item(0).getTextContent()); System.out.println("Marks : " + eElement.getElementsByTagName("marks").item(0).getTextContent()); } } } catch (Exception e) { e.printStackTrace(); } } } ``` 在上面的代码中,我们使用了 DocumentBuilder 类来解析 XML 文件。首先,我们创建了一个 DocumentBuilder 对象,然后使用它的 parse() 方法来解析 XML 文件。最后,我们遍历 XML 文件中的所有节点,并打印出它们的内容。 ### 回答2: Java解析XML文件的核心代码通常使用javax.xml.parsers包中的DOM解析器或SAX解析器。下面是这两种解析方式的核心代码示例: 1. 使用DOM解析器: ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; import org.w3c.dom.Document; import org.w3c.dom.NodeList; import org.w3c.dom.Node; public class XMLParser { public static void main(String[] args) { try { // 创建DOM解析器工厂 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); // 创建DOM解析器 DocumentBuilder builder = factory.newDocumentBuilder(); // 解析XML文件,返回Document对象 Document document = builder.parse("file.xml"); // 获取指定节点的值 NodeList nodeList = document.getElementsByTagName("element"); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); System.out.println(node.getTextContent()); } } catch (Exception e) { e.printStackTrace(); } } } ``` 2. 使用SAX解析器: ```java import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.helpers.DefaultHandler; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; public class XMLParser { public static void main(String[] args) { try { // 创建SAX解析器工厂 SAXParserFactory factory = SAXParserFactory.newInstance(); // 创建SAX解析器 SAXParser parser = factory.newSAXParser(); // 创建自定义的事件处理器 MyHandler handler = new MyHandler(); // 解析XML文件 parser.parse("file.xml", handler); } catch (Exception e) { e.printStackTrace(); } } } class MyHandler extends DefaultHandler { @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { if (qName.equalsIgnoreCase("element")) { // 获取元素属性值 String attributeValue = attributes.getValue("attribute"); System.out.println(attributeValue); } } @Override public void characters(char[] ch, int start, int length) throws SAXException { // 获取元素文本内容 String text = new String(ch, start, length); System.out.println(text); } } ``` 以上代码分别演示了使用DOM解析器和SAX解析器来解析XML文件,并获取指定节点的值或属性值。实际使用时,可以根据具体需求进行适当的修改和扩展。 ### 回答3: Java解析XML文件的核心代码通常涉及以下步骤: 1. 创建一个DocumentBuilder对象,用于解析XML文件。 ```java DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); ``` 2. 通过DocumentBuilder对象解析XML文件,并返回一个表示整个文件的Document对象。 ```java Document document = builder.parse(new File("file.xml")); ``` 3. 从Document对象中获取根元素。 ```java Element root = document.getDocumentElement(); ``` 4. 通过根元素遍历XML文件的每个元素或节点。 ```java NodeList nodeList = root.getChildNodes(); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); // 进一步处理该节点的相关操作 } ``` 5. 对于每个节点,可以通过其标签名称、属性等获取相应的信息。 ```java if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; String tagName = element.getTagName(); String attributeValue = element.getAttribute("attributeName"); // 处理该元素或节点的相关操作 } ``` 6. 对于每个节点,还可以获取其文本内容。 ```java if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; String textContent = element.getTextContent(); // 处理该元素或节点的相关操作 } ``` 7. 另外,还可以使用XPath来解析XML文件,以简化代码和提高效率。可以通过XPath对象的evaluate()方法获取满足条件的节点列表。 ```java XPathFactory xPathFactory = XPathFactory.newInstance(); XPath xpath = xPathFactory.newXPath(); String expression = "//tagName"; NodeList nodeList = (NodeList) xpath.evaluate(expression, document, XPathConstants.NODESET); ``` 这些是Java解析XML文件的一些核心代码,可以根据具体的需求进行相应的扩展和优化。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值