2017-04-04 81 views
0

是否有Java庫可以讓您提取/創建XML文檔,因此最終結果是文檔的「準系統」XML結構。使用Java提取XML結構

<result> 
    <rowset name="kills" key="killID" columns="killID,solarSystemID,killTime,moonID"> 
     <row killID="54933226" solarSystemID="31001222" killTime="2016-07-03 22:29:19" moonID="0"> 
     <victim characterID="93811169" characterName="Madcat326" corporationID="98008818" corporationName="Haight Industries LLC" allianceID="0" allianceName="" factionID="0" factionName="" damageTaken="63039" shipTypeID="17918" x="59788513854.179" y="-13687850177.3741" z="157817245029.115" /> 
     <rowset name="attackers" columns="characterID,characterName,corporationID,corporationName,allianceID,allianceName,factionID,factionName,securityStatus,damageDone,finalBlow,weaponTypeID,shipTypeID"> 
      <row characterID="91316135" characterName="Celeo Servasse" corporationID="98134538" corporationName="Wormbro" allianceID="0" allianceName="" factionID="0" factionName="" securityStatus="-1.0646369409683" damageDone="7825" finalBlow="1" weaponTypeID="3520" shipTypeID="12003" /> 
      <row characterID="95273329" characterName="Mupoc Kashuken" corporationID="98134538" corporationName="Wormbro" allianceID="0" allianceName="" factionID="0" factionName="" securityStatus="-0.2" damageDone="16656" finalBlow="0" weaponTypeID="31882" shipTypeID="12023" /> 
     </rowset> 
     <rowset name="items" columns="typeID,flag,qtyDropped,qtyDestroyed,singleton"> 
      <row typeID="394" flag="20" qtyDropped="1" qtyDestroyed="0" singleton="0" /> 
      <row typeID="24427" flag="32" qtyDropped="0" qtyDestroyed="1" singleton="0" /> 
      <row typeID="2446" flag="87" qtyDropped="1" qtyDestroyed="1" singleton="0" /> 
      <row typeID="28209" flag="87" qtyDropped="2" qtyDestroyed="0" singleton="0" /> 
     </rowset> 
     </row> 
    </rowset> 
</result> 

將重建爲類似

<result> 
    <rowset name="kills" key="killID" columns="killID,solarSystemID,killTime,moonID"> 
     <row killID="54933226" solarSystemID="31001222" killTime="2016-07-03 22:29:19" moonID="0"> 
     <victim characterID="93811169" characterName="Madcat326" corporationID="98008818" corporationName="Haight Industries LLC" allianceID="0" allianceName="" factionID="0" factionName="" damageTaken="63039" shipTypeID="17918" x="59788513854.179" y="-13687850177.3741" z="157817245029.115" /> 
     <rowset name="attackers" columns="characterID,characterName,corporationID,corporationName,allianceID,allianceName,factionID,factionName,securityStatus,damageDone,finalBlow,weaponTypeID,shipTypeID"> 
      <row characterID="91316135" characterName="Celeo Servasse" corporationID="98134538" corporationName="Wormbro" allianceID="0" allianceName="" factionID="0" factionName="" securityStatus="-1.0646369409683" damageDone="7825" finalBlow="1" weaponTypeID="3520" shipTypeID="12003" /> 
     </rowset> 
     <rowset name="items" columns="typeID,flag,qtyDropped,qtyDestroyed,singleton"> 
      <row typeID="394" flag="20" qtyDropped="1" qtyDestroyed="0" singleton="0" /> 
     </rowset> 
     </row> 
    </rowset> 
</result> 

或者我怎麼可以提取/創建XML文檔的結構?

如果這個過程被稱爲別的東西,請讓我知道。

+0

您的意思是你想要生成一個模式? – Paddyd

+0

這聽起來並不完全錯誤,我真正想要的是能夠獲取XML文檔並獲得其構建結構。 –

回答

0

要得到一個有用的答案,你應該解釋你期望能夠對結果做什麼。

您可以使用在線工具(如http://www.freeformatter.com/xsd-generator.htmlhttp://xmlgrid.net/xml2xsd.html)以XSD格式提取結構,那麼您在尋找什麼?

<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema"> 
    <xs:element name="result"> 
    <xs:complexType> 
     <xs:sequence> 
     <xs:element name="rowset"> 
      <xs:complexType> 
      <xs:sequence> 
       <xs:element name="row"> 
       <xs:complexType> 
        <xs:sequence> 
        <xs:element name="victim"> 
         <xs:complexType> 
         <xs:simpleContent> 
          <xs:extension base="xs:string"> 
          <xs:attribute type="xs:int" name="characterID"/> 
          <xs:attribute type="xs:string" name="characterName"/> 
          <xs:attribute type="xs:int" name="corporationID"/> 
          <xs:attribute type="xs:string" name="corporationName"/> 
          <xs:attribute type="xs:byte" name="allianceID"/> 
          <xs:attribute type="xs:string" name="allianceName"/> 
          <xs:attribute type="xs:byte" name="factionID"/> 
          <xs:attribute type="xs:string" name="factionName"/> 
          <xs:attribute type="xs:int" name="damageTaken"/> 
          <xs:attribute type="xs:short" name="shipTypeID"/> 
          <xs:attribute type="xs:float" name="x"/> 
          <xs:attribute type="xs:float" name="y"/> 
          <xs:attribute type="xs:float" name="z"/> 
          </xs:extension> 
         </xs:simpleContent> 
         </xs:complexType> 
        </xs:element> 
        <xs:element name="rowset" maxOccurs="unbounded" minOccurs="0"> 
         <xs:complexType> 
         <xs:sequence> 
          <xs:element name="row" maxOccurs="unbounded" minOccurs="0"> 
          <xs:complexType> 
           <xs:simpleContent> 
           <xs:extension base="xs:string"> 
            <xs:attribute type="xs:int" name="characterID" use="optional"/> 
            <xs:attribute type="xs:string" name="characterName" use="optional"/> 
            <xs:attribute type="xs:int" name="corporationID" use="optional"/> 
            <xs:attribute type="xs:string" name="corporationName" use="optional"/> 
            <xs:attribute type="xs:byte" name="allianceID" use="optional"/> 
            <xs:attribute type="xs:string" name="allianceName" use="optional"/> 
            <xs:attribute type="xs:byte" name="factionID" use="optional"/> 
            <xs:attribute type="xs:string" name="factionName" use="optional"/> 
            <xs:attribute type="xs:float" name="securityStatus" use="optional"/> 
            <xs:attribute type="xs:short" name="damageDone" use="optional"/> 
            <xs:attribute type="xs:byte" name="finalBlow" use="optional"/> 
            <xs:attribute type="xs:short" name="weaponTypeID" use="optional"/> 
            <xs:attribute type="xs:short" name="shipTypeID" use="optional"/> 
            <xs:attribute type="xs:short" name="typeID" use="optional"/> 
            <xs:attribute type="xs:byte" name="flag" use="optional"/> 
            <xs:attribute type="xs:byte" name="qtyDropped" use="optional"/> 
            <xs:attribute type="xs:byte" name="qtyDestroyed" use="optional"/> 
            <xs:attribute type="xs:byte" name="singleton" use="optional"/> 
           </xs:extension> 
           </xs:simpleContent> 
          </xs:complexType> 
          </xs:element> 
         </xs:sequence> 
         <xs:attribute type="xs:string" name="name" use="optional"/> 
         <xs:attribute type="xs:string" name="columns" use="optional"/> 
         </xs:complexType> 
        </xs:element> 
        </xs:sequence> 
        <xs:attribute type="xs:int" name="killID"/> 
        <xs:attribute type="xs:int" name="solarSystemID"/> 
        <xs:attribute type="xs:string" name="killTime"/> 
        <xs:attribute type="xs:byte" name="moonID"/> 
       </xs:complexType> 
       </xs:element> 
      </xs:sequence> 
      <xs:attribute type="xs:string" name="name"/> 
      <xs:attribute type="xs:string" name="key"/> 
      <xs:attribute type="xs:string" name="columns"/> 
      </xs:complexType> 
     </xs:element> 
     </xs:sequence> 
    </xs:complexType> 
    </xs:element> 
</xs:schema> 
+0

嗨特里斯坦,謝謝你的回覆!除了能夠在沒有冗餘數據的情況下查看文檔結構(如行,父節點內沒有子節點)之外,我不打算將結果/輸出用於任何其他內容。我試圖在上面的帖子/主題中展示這一點。 –

+0

在瀏覽器中使用XML編輯器或XML查看器? – jschnasse

+0

是的,正如@jschnasse所建議的那樣,您可以在任何XML編輯器(如瀏覽器)中摺疊包含多個元素的級別。 – Tristan

0

以下XSLT轉換格式可能有助於刪除重複的子行元素。你可以從java代碼運行這個轉換器。

<?xml version="1.0" encoding="UTF-8"?> 
    <xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
    <xsl:template match="/result"> 
     <result> 
     <rowset> 
     <xsl:copy-of select="rowset/@*"/>  
     <row> 
     <xsl:copy-of select="rowset/row/@*"/>  
     <victim> 
      <xsl:copy-of select="rowset/row/victim/@*"/>  
     </victim>   
     <rowset>  
      <xsl:copy-of select="rowset/row/rowset[@name='attackers']/@*"/> 
      <row> 
      <xsl:copy-of select="rowset/row/rowset[@name='attackers']/row[1]/@*"/> 
      </row> 
     </rowset> 
      <rowset>  
      <xsl:copy-of select="rowset/row/rowset[@name='items']/@*"/> 
      <row> 
      <xsl:copy-of select="rowset/row/rowset[@name='items']/row[1]/@*"/> 
      </row> 
     </rowset> 
     </row> 
     </rowset> 
     </result> 
     </xsl:template> 
    </xsl:stylesheet>