2016-06-15 3 views
1

Я застреваю, пытаясь понять, как отменить маркер XML-файла, поставляемого IBM Cognos.Unmarshalling без уникальных имен узлов

Структура не предоставляет уникальные имена для разных дочерних узлов под элементом, но есть блок метаданных, который определяет порядок значений.

Это упрощенный образец XML-файла.

<?xml version="1.0" encoding="utf-8"?> 
<dataset xmlns="http://developer.cognos.com/schemas/xmldata/1/" xmlns:xs="http://www.w3.org/2001/XMLSchema-instance"> 
<!-- 
<dataset 
    xmlns="http://developer.cognos.com/schemas/xmldata/1/" 
    xmlns:xs="http://www.w3.org/2001/XMLSchema-instance" 
    xs:schemaLocation="http://developer.cognos.com/schemas/xmldata/1/ xmldata.xsd" 
> 
--> 
    <metadata> 
      <item name="EmployeeID" type="xs:string" length="20"/> 
      <item name="firstName" type="xs:string" length="50"/> 
      <item name="lastName" type="xs:string" length="50"/> 
    </metadata> 
    <data> 
     <row> 
      <value>EMP1</value> 
      <value>Joe</value> 
      <value>Blogs</value> 
     </row> 
     <row> 
      <value>EMP2</value> 
      <value>Mary</value> 
      <value>Soap</value> 
     </row> 
    </data> 
</dataset> 

Я использую Spring ОХМЫ и Castor для этого проекта, и я не имею никакого контроля над форматом XML, как я потянув его с помощью веб-службы из сторонней системы.

Обновление: Я не против замены Кастора для другой сортировочной/unmarshalling библиотеки.

ответ

1

Магия XSLT на помощь. Запустив предоставленный XML через следующую таблицу стилей XSLT, я смог создать XML-файл, который я смог бы затем правильно отменить.

<?xml version="1.0" encoding="iso-8859-1"?> 
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
    xmlns:cognos="http://developer.cognos.com/schemas/xmldata/1/"> 
    <xsl:output method="xml" version="1.0" encoding="UTF-8" standalone="yes" indent="yes"/> 
    <xsl:template match="/"> 
    <xsl:element name="DataSet"> 
     <xsl:for-each select="//*[name()='row']"> 
     <xsl:variable name="row" select="position()" /> 
     <xsl:element name="Row"> 
      <xsl:for-each select="//*[name()='item']"> 
      <xsl:variable name="elementName" select="@name" /> 
      <xsl:variable name="index" select="position()" /> 
      <xsl:element name="{translate($elementName,' ','_')}"> 
       <xsl:value-of select="//cognos:row[$row]/cognos:value[$index]" /> 
      </xsl:element> 
      </xsl:for-each> 
     </xsl:element> 
     </xsl:for-each> 
    </xsl:element> 
    </xsl:template> 
</xsl:stylesheet> 

Это превратило файл XML следующим образом

<?xml version="1.0" encoding="UTF-8" standalone="yes"?> 
<DataSet> 
    <Row> 
    <EmployeeID>EMP1</EmployeeID> 
    <firstName>Joe</firstname> 
    <lastName>Blogs</lastName> 
    </Row> 
    <Row> 
    <EmployeeID>EMP2</EmployeeID> 
    <firstName>Mary</firstname> 
    <lastName>Soap</lastName> 
    </Row> 
</DataSet>