xml解析工具类

package com.framework.loippi.utils.yinliang;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.json.JSONObject;
import org.json.XML;

import java.io.ByteArrayInputStream;
import java.io.UnsupportedEncodingException;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

/**
 * <p>
 * xml工具类
 * </p>
 *
 * @date 2019/12/5 17:40
 */
public class XmlUtil {

    //编码
    private static final String charsetName = "GBK";

    /**
     * 获取内容-递归
     */
    private static Map<String, Object> getContentMap(Element root, Iterator it) {
        Map<String, Object> rootMap = new HashMap<>();
        Map<String, Object> nextRootMap = new HashMap<>();
        while (it.hasNext()) {
            Element nextRoot = (Element) it.next();
            Iterator nextIt = nextRoot.elementIterator();
            if (nextIt.hasNext()) {
                //当前xml标签下,存嵌套了其他标签
                Map<String, Object> nextContentMap = getContentMap(nextRoot, nextIt);
                nextRootMap.putAll(nextContentMap);
            } else {
                //当前xml标签下,只有值,未嵌套其他标签
                nextRootMap.put(nextRoot.getName(), nextRoot.getTextTrim());
            }
        }
        rootMap.put(root.getName(), nextRootMap);
        return rootMap;
    }

    /**
     * xml转map
     *
     * @param xml xml字符串
     * @return map对象
     */
    public static Map<String, Object> xmlToMap(String xml) {
        try {
            SAXReader reader = new SAXReader();
            String xmlStr = reader.read(new ByteArrayInputStream(xml.getBytes(charsetName))).asXML();
            Document document = DocumentHelper.parseText(xmlStr);
            Element root = document.getRootElement();
            Iterator it = root.elementIterator();
            //递归 xml转 map
            return getContentMap(root, it);
        } catch (DocumentException | UnsupportedEncodingException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * map转xml
     *
     * @param map map参数值
     * @return xml字符串
     */
    public static String mapToXml(Map<String, Object> map) {
        JSONObject json = new JSONObject(map);
        return "<?xml version=\"1.0\" encoding=\""+charsetName+"\"?>" + XML.toString(json);
    }

    /**
     * xml转json
     *
     * @param xmlString xml字符串
     * @return JSONObject对象
     */
    public static JSONObject xmlToJSONObject(String xmlString) {
        return XML.toJSONObject(xmlString);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
package com.hexiang.utils; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.NodeList; /** * 本类是专门解析XML文件的,主要用于为系统读取自己的配置文件时提供最方便的解析操作 * @author HX * */ public class XmlManager { /** * 得到某节点下某个属性的值 * @param element 要获取属性的节点 * @param attributeName 要取值的属性名称 * @return 要获取的属性的值 * @author HX_2010-01-12 */ public static String getAttribute( Element element, String attributeName ) { return element.getAttribute( attributeName ); } /** * 获取指定节点下的文本 * @param element 要获取文本的节点 * @return 指定节点下的文本 * @author HX_2010-01-12 */ public static String getText( Element element ) { return element.getFirstChild().getNodeValue(); } /** * 解析某个xml文件,并在内存中创建DOM树 * @param xmlFile 要解析的XML文件 * @return 解析某个配置文件后的Document * @throws Exception xml文件不存在 */ public static Document parse( String xmlFile ) throws Exception { // 绑定XML文件,建造DOM树 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); DocumentBuilder db = dbf.newDocumentBuilder(); Document domTree = db.parse( xmlFile ); return domTree; } /** * 获得某节点下的某个子节点(指定子节点名称,和某个属性的值) * 即获取parentElement下名字叫childName,并且属性attributeName的值为attributeValue的子结点 * @param parentElement 要获取子节点的那个父节点 * @param childName 要获取的子节点名称 * @param attributeName 要指定的属性名称 * @param attributeValue 要指定的属性的值 * @return 符合条件的子节点 * @throws Exception 子结点不存在或有多个符合条件的子节点 * @author HX_2008-12-01 */ public static Element getChildElement( Element parentElement, String childName, String attributeName, String attributeValue ) throws Exception { NodeList list = parentElement.getElementsByTagName( childName ); int count = 0; Element curElement = null; for ( int i = 0 ; i < list.getLength() ; i ++ ) { Element child = ( Element )list.item( i ); String value = child.getAttribute( attributeName ); if ( true == value.equals( attributeValue ) ) { curElement =
好的,关于 Android XML 解析工具类,可以使用 Android 提供的 XmlPullParser 类来解析 XML 文件。XmlPullParser 是 Android 系统中提供的一个轻量级的解析器,用于解析 XML 文件。 下面是一个简单的示例代码,展示如何使用 XmlPullParser 来解析 XML 文件: ```java public static List<Entry> parse(InputStream is) throws XmlPullParserException, IOException { List<Entry> entries = new ArrayList<>(); XmlPullParser parser = Xml.newPullParser(); parser.setFeature(XmlPullParser.FEATURE_PROCESS_NAMESPACES, false); parser.setInput(is, null); int eventType = parser.getEventType(); Entry currentEntry = null; while (eventType != XmlPullParser.END_DOCUMENT) { String name = parser.getName(); switch (eventType) { case XmlPullParser.START_TAG: if (name.equals("entry")) { currentEntry = new Entry(); } else if (currentEntry != null) { if (name.equals("title")) { currentEntry.setTitle(parser.nextText()); } else if (name.equals("link")) { currentEntry.setLink(parser.nextText()); } else if (name.equals("description")) { currentEntry.setDescription(parser.nextText()); } else if (name.equals("pubDate")) { currentEntry.setPubDate(parser.nextText()); } } break; case XmlPullParser.END_TAG: if (name.equals("entry") && currentEntry != null) { entries.add(currentEntry); } break; } eventType = parser.next(); } return entries; } ``` 在这个示例中,我们使用 XmlPullParser 解析 XML 文件,并将每个 entry 元素解析为一个 Entry 对象。在解析过程中,我们使用了 XmlPullParser 的一些方法,例如 parser.getEventType()、parser.getName()、parser.nextText() 等。 希望这个示例代码能够帮助你了解如何使用 XmlPullParser 类来解析 XML 文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值