помочь с преобразованием XML - PullRequest
0 голосов
/ 05 февраля 2011

как я могу преобразовать что-то вроде

<NewDataSet>
 <Table>
   <dnis>Dec 5 Call</dnis>
   <monthval>12</monthval>
   <Totalcalls>2</Totalcalls>
   <AvgDuration>23</AvgDuration>
   <TotalHangups>34</TotalHangups>
   <TotalHangupsaftClosedMsg>23</TotalHangupsaftClosedMsg>
   <TotalCallstoAgent>2</TotalCallstoAgent>
   <Row>
     <dnis>Dec 5 Call</dnis>
     <Week>Dec  5-Dec 11</Week>
     <Totalcalls>2</Totalcalls>
     <AvgDuration>23</AvgDuration>
     <TotalHangups>34</TotalHangups>
     <TotalHangupsaftClosedMsg>23</TotalHangupsaftClosedMsg>
     <TotalCallstoAgent>2</TotalCallstoAgent>
   </Row>
   <Row>
     <dnis>Dec 5 Call</dnis>
     <Week>Dec  5-Dec 11</Week>
     <Totalcalls>2</Totalcalls>
     <AvgDuration>23</AvgDuration>
     <TotalHangups>34</TotalHangups>
     <TotalHangupsaftClosedMsg>23</TotalHangupsaftClosedMsg>
     <TotalCallstoAgent>2</TotalCallstoAgent>
  </Row>
 </Table>
</NewDataSet>

в

<?xml version="1.0" encoding="utf-8"?>
  <NewDataSet>
    <Table>
      <Header>
        <dnis>Dec 5 Call</dnis>
        <monthval>12</monthval>
        <Totalcalls>2</Totalcalls>
        <AvgDuration>23</AvgDuration>
        <TotalHangups>34</TotalHangups>
        <TotalHangupsaftClosedMsg>23</TotalHangupsaftClosedMsg>
        <TotalCallstoAgent>2</TotalCallstoAgent>
      </Header>
      <Body>
        <Row>
          <dnis>Dec 5 Call</dnis>
          <Week>Dec  5-Dec 11</Week>
          <Totalcalls>2</Totalcalls>
          <AvgDuration>23</AvgDuration>
          <TotalHangups>34</TotalHangups>
          <TotalHangupsaftClosedMsg>23</TotalHangupsaftClosedMsg>
          <TotalCallstoAgent>2</TotalCallstoAgent>
        </Row>
        <Row>
          <dnis>Dec 5 Call</dnis>
          <Week>Dec  5-Dec 11</Week>
          <Totalcalls>2</Totalcalls>
          <AvgDuration>23</AvgDuration>
          <TotalHangups>34</TotalHangups>
          <TotalHangupsaftClosedMsg>23</TotalHangupsaftClosedMsg>
          <TotalCallstoAgent>2</TotalCallstoAgent>
        </Row>
      </Body>
    </Table>
  </NewDataSet>

Ответы [ 3 ]

1 голос
/ 05 февраля 2011

Попробуйте это:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:template match="/NewDataSet">
      <NewDataSet>
        <xsl:for-each select="Table">
        <Table>
          <Header>
            <xsl:for-each select="*[name() != 'Row']">
              <xsl:copy-of select="." />
            </xsl:for-each>
          </Header>
          <Body>
            <xsl:for-each select="Row">
              <xsl:copy-of select="." />
            </xsl:for-each>
          </Body>
        </Table>
        </xsl:for-each>
      </NewDataSet>
  </xsl:template>
</xsl:stylesheet>
1 голос
/ 05 февраля 2011

Решение на основе шаблона идентификации:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

  <xsl:template match="Table">
    <xsl:copy>
      <Header>
        <xsl:apply-templates select="*[not(self::Row)]"/>
      </Header>
      <Body>
        <xsl:apply-templates select="Row"/>
      </Body>
    </xsl:copy>
  </xsl:template>

  <xsl:template match="@* | node()">
    <xsl:copy>
      <xsl:apply-templates select="@* | node()"/>
    </xsl:copy>
  </xsl:template>

</xsl:stylesheet>
0 голосов
/ 05 февраля 2011

Вы либо используете XSLT, либо просто анализируете первый Xml, извлекаете узлы и создаете второй Xml.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...