Java dom解析 字符串对象

1,单层对象解析


 String str = "<string xmlns=\"http://tempuri.org/\">I live in China。我在中国。</string>";
 

2,代码


public static void main(String[] args) {
         try{
            String str = "<string xmlns=\"http://tempuri.org/\">I live in China。我在中国。</string>";
            Document doc = null;
            try {
                doc = DocumentHelper.parseText(str);
            } catch (DocumentException e2) {
                e2.printStackTrace();
            }
            Element root = doc.getRootElement();// 指向根节点
            System.out.println("start.getTextTrim()=" + root.getTextTrim());//获取根节点文本内容
            
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    

输出结果:

在这里插入图片描述


-----------------------------------------------------------------------------分界线----------------------------------------------------------------------

1,多层对象解析


	<string xmlns=\"http://tempuri.org/\">
	<p><li>I live in China。我在中国。</li><li>My home is in hubbe。</li></p>
	<p>I speak Chinese。我会说中文。</p>
	</string>

2,代码


    public static void main(String[] args) {
         try{
            String str = "<string xmlns=\"http://tempuri.org/\">" +
                    "<p><li>I live in China。我在中国。</li><li>My home is in hubbe。</li></p>" +
                    "<p>I speak Chinese。我会说中文。</p>" +
                    "</string>";
            Document doc = null;
            try {
                doc = DocumentHelper.parseText(str);
            } catch (DocumentException e2) {
                e2.printStackTrace();
            }
            Element root = doc.getRootElement();// 指向根节点
             // p解析
            List<Element> elementList = root.elements("p");//获取所有同级p标签
            System.out.println("p2.getTextTrim():" + elementList.get(1).getText());
            System.out.println("p2.getTextTrim():" + elementList.get(1).asXML());
             try {
                 Element p = root.element("p");//获取第一个p标签
                 List lstTime = p.elements("li");// 所有的Item节点
                 for (int i = 0; i < lstTime.size(); i++) {
                     Element etime = (Element) lstTime.get(i);
                     System.out.println("root【"+i+"】.getTextTrim():" + etime.getTextTrim());
                 }
             } catch (Exception e) {
                 e.printStackTrace();
             }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    

输出结果:

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用 Java 中的 dom4j 库来解析 XML 字符串。以下是一个示例代码: ```java import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; public class XmlParser { public static void main(String[] args) { String xmlString = "<root><element1>Value 1</element1><element2>Value 2</element2></root>"; try { // 创建一个新的 SAXReader 对象 SAXReader reader = new SAXReader(); // 将 XML 字符串解析Document 对象 Document document = reader.read(new ByteArrayInputStream(xmlString.getBytes())); // 获取根元素 Element root = document.getRootElement(); // 遍历子元素 for (Iterator<Element> iter = root.elementIterator(); iter.hasNext();) { Element element = iter.next(); // 输出元素名和文本内容 System.out.println("Element Name: " + element.getName()); System.out.println("Element Value: " + element.getText()); } } catch (DocumentException e) { e.printStackTrace(); } } } ``` 在上面的示例中,我们创建了一个 XML 字符串并将其解析为一个 dom4j 的 `Document` 对象。然后我们可以通过该对象获取根元素,并通过迭代器遍历其子元素,输出元素名和文本内容。 记得将 dom4j 添加到你的项目依赖中。你可以在 Maven 中添加以下依赖: ```xml <dependency> <groupId>org.dom4j</groupId> <artifactId>dom4j</artifactId> <version>1.6.1</version> </dependency> ``` 希望对你有所帮助!如果你有更多问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值