java xsd解析_java dom4j解析XSD文件

java xsd解析_java dom4j解析XSD文件1 用 DOM4J 解析 XSD 文件 找出 XSD 文件中所有的 element type 的定义 xsd 文件有 4W 多行 最终找出的结果是 element 和 type 定义有 6000 多个 2 递归找出指定 type 所用到的所有关联的元素 其中有用到 XPATH 来查找结点根据 type 在 xsd 文件中查找 找到有 type 和 element 是自定义的就递归下去继续往下找 直到找到最后所有的 type 和 element 都是 XSD 自带

1.用DOM4J解析XSD文件,找出XSD文件中所有的element,type的定义,(xsd文件有4W多行),最终找出的结果是element和type定义有6000多个,

2.递归找出指定type所用到的所有关联的元素,其中有用到XPATH来查找结点

根据type在xsd文件中查找,找到有type和element是自定义的就递归下去继续往下找,直到找到最后所有的type和element都是XSD自带的菜结束

package day3;

import java.io.BufferedWriter;

import java.io.File;

import java.io.FileWriter;

import java.io.IOException;

import java.io.StringReader;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.HashSet;

import java.util.Iterator;

import java.util.List;

import java.util.Map;

import java.util.Set;

import javax.xml.xpath.XPath;

import javax.xml.xpath.XPathConstants;

import javax.xml.xpath.XPathExpressionException;

import javax.xml.xpath.XPathFactory;

import org.dom4j.Attribute;

import org.dom4j.Document;

import org.dom4j.DocumentException;

import org.dom4j.Element;

import org.dom4j.Node;

import org.dom4j.QName;

import org.dom4j.Text;

import org.dom4j.io.SAXReader;

import org.dom4j.xpath.DefaultXPath;

import org.w3c.dom.NodeList;

import org.xml.sax.InputSource;

public class Test {

/

* @param args

* @throws DocumentException

* @throws IOException

* @throws XPathExpressionException

*/

public static Set listNotFindName = new HashSet();

public static Set set = new HashSet();//当前type查找出来的所有相关type定义

public static Set setAll = new HashSet();//第一次是全部的 ,removeall()以后是没用的type

//public static Set settoRemeave = new HashSet();

public static boolean isEnd =false;

public static String beginName=”TXLifeResponse”;

public static void main(String[] args) throws DocumentException, IOException, XPathExpressionException {

// TODO Auto-generated method stub

SAXReader saxReader = new SAXReader();

Document document = saxReader.read(new File(“bbxsd.xml”));

//Document documentAll = saxReader.read(new File(“bbxsd.xml”));

Element root = document.getRootElement();

for (Iterator iter = root.elementIterator(); iter.hasNext();)

{

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

System.out.println(e.attributeValue(“name”));

setAll.add(e.attributeValue(“name”));

}

Map xmlMap = new HashMap();

xmlMap.put(“xsd”, “http://www.w3.org/2001/XMLSchema”);

DefaultXPath xpath = new DefaultXPath(“/xsd:schema/xsd:simpleType[@name='”+beginName+”‘]|/xsd:schema/xsd:element[@name='”+beginName+”‘]|/xsd:schema/xsd:complexType[@name='”+beginName+”‘]”);

xpath.setNamespaceURIs(xmlMap);

Element e =(Element) xpath.selectSingleNode(document);

//System.out.println(e.asXML());

getName(e);

Iterator iterator=set.iterator();

Iterator iterator1=listNotFindName.iterator();

System.out.println(“set.size()===”+set.size());

System.out.println(“before remove setAll.size()===”+setAll.size());

removeAll();

System.out.println(“after remove setAll.size()===”+setAll.size());

System.out.println(“listNotFindName.size()===”+listNotFindName.size());

writeSetToFile(setAll,”delete”);

writeSetToFile(set,”allsearchType”);

writeSetToFile(listNotFindName,”listNotFindName”);

}

static Element getElementByName(String name) throws DocumentException

{

//System.out.println(“getElementByName(name) name is “+name);

SAXReader saxReader = new SAXReader();

Document document = saxReader.read(new File(“bbxsd.xml”));

Map xmlMap = new HashMap();

xmlMap.put(“xsd”, “http://www.w3.org/2001/XMLSchema”);

DefaultXPath xpath = new DefaultXPath(“/xsd:schema/xsd:simpleType[@name='”+beginName+”‘]|/xsd:schema/xsd:complexType[@name='”+beginName+”‘]|/xsd:schema/xsd:element[@name='”+beginName+”‘]”);

xpath.setNamespaceURIs(xmlMap);

//Element e = (Element)document.selectSingleNode(“/schema/simpleType[@name='”+name+”‘]|/schema/complexType[@name='”+name+”‘]|/schema/element[@name='”+name+”‘]”);

//Element e = (Element)document.selectSingleNode(“/schema/simpleType[@name='”+name+”‘ and namespace-uri()=’http://www.w3.org/2001/XMLSchema’]|/schema/complexType[@name='”+name+”‘ and namespace-uri()=’http://www.w3.org/2001/XMLSchema’]|/schema/element[@name='”+name+”‘ and namespace-uri()=’http://www.w3.org/2001/XMLSchema’]”);

Element e =(Element) xpath.selectSingleNode(document);

//System.out.println(“e.elements is “+e.elements().size());

return e;

}

public static void getName(Element e) throws DocumentException{

//System.out.println(“begin get name:”+beginName);

if(e==null){

System.out.println(“can not find e:”+beginName);

listNotFindName.add(beginName);

set.remove(beginName);

return;

}

String xml = e.asXML();

//System.out.println(xml);

SAXReader saxReader = new SAXReader();

InputSource in = new InputSource(new StringReader(xml));

Document document = saxReader.read(in);

Map xmlMap = new HashMap();

xmlMap.put(“xsd”, “http://www.w3.org/2001/XMLSchema”);

DefaultXPath xpath = new DefaultXPath(“//@name|//@type|//@ref|//@base”);   xpath.setNamespaceURIs(xmlMap);   List elements = xpath.selectNodes(document);   for(int i=0;i iterator=set.iterator();          while(iterator.hasNext()){            //System.out.println(iterator.next());           wr.write(iterator.next());           wr.newLine();           wr.flush();          }   } catch (IOException e) {    // TODO Auto-generated catch block    e.printStackTrace();   }finally{    try {     wr.close();    } catch (IOException e) {     // TODO Auto-generated catch block     e.printStackTrace();    }   }     } }

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233272.html原文链接:https://javaforall.net

(0)
上一篇 2025年8月2日 下午1:01
下一篇 2025年8月2日 下午1:22


相关推荐

  • 数据库锁分类和总结

    数据库锁分类和总结锁锁是网络数据库中的一个非常重要的概念 当多个用户同时对数据库并发操作时 会带来数据不一致的问题 所以 锁主要用于多用户环境下保证数据库完整性和一致性 帮助理解 以商场的试衣间为例 每个试衣间都可供多个消费者使用 因此 可能出现多个消费者同时需要使用试衣间试衣服 为了避免冲突 试衣间装了锁 某一个试衣服的人在试衣间里把锁锁住了 其他顾客就不能从外面打开了 只能等待里面的顾客试完衣服

    2026年3月18日
    2
  • 无穷小分析理论_无穷小是一个过程

    无穷小分析理论_无穷小是一个过程一般读者对无穷小微积分只是略知一二,其实这是不够的。现将有关文章引用如下,供读者参考。袁萌 12月23日非标准分析概念又可称为实无穷小分析)(英语:Non-standardanalysis)是一个数学分支,它用严格定义的无穷小的数(infinitesimalnumber)的概念来构建数学分析大厦。1历史2动机2.1历史上的原因2.2教学上的原因2.3技术上的原因3无穷小分析的各种建立

    2022年8月11日
    7
  • 深入解析HashMap和currentHashMap源码以及实现原理「建议收藏」

    深入解析HashMap和currentHashMap源码以及实现原理「建议收藏」深入解析HashMap和ConcurrentHashMapy源码以及底层原理前言HashMap和ConcurrentHashMap,这两个相信大家都不陌生,在面试中基本上是必问的,以及在实际开发过程中也是比用的,那么看了这篇文章,无论在面试还是在实际开发中都可以顺手拈来,得心应手了。HashMap基于Map接口实现,元素以键值对的方式存储,并且允许使用null建和null 值, 因为key不允许重复,因此只能有一个键为null,另外HashMap不能保证放入元素的顺序,它是无序的,和放入的顺序并

    2022年6月18日
    43
  • 如何利用 Webshell 诊断 EDAS Serverless 应用

    如何利用 Webshell 诊断 EDAS Serverless 应用

    2021年7月4日
    60
  • 如何查看pip版本

    如何查看pip版本Windows 系统如何查看 pip 版本直接运行 pipshowpip

    2026年3月19日
    3
  • sqlserver数据库同步工具_sql server数据库安装

    sqlserver数据库同步工具_sql server数据库安装 一、确认数据库运行环境是否配置正确打开SQLServerManagementStudio,新建查询: select*fromsys.servers GO //这里可得到原来的计算机名称。然后将其记录下来(复制即可)  看这里的name是否和你的服务器的计算机名称一样,如果一样可以跳到文档(二),否则请按如下操作更改 新建查询:

    2022年10月10日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号