сортировать схему выходного плоского файла в Biztalk на основе одного узла

У меня есть схема плоского файла в качестве вывода после выполнения сложного сопоставления.

Теперь я хочу отсортировать данные схемы плоского файла на основе значений одного узла, поскольку в конце я сохраняю эту схему как csv. (по моему требованию)

Поэтому, когда я открываю свой CSV, данные должны быть отсортированы в алфавитном порядке на основе одного узла.

Есть ли способ сделать это?

Я могу добиться этого при заполнении данных в схеме. Просто интересно, есть ли способ отсортировать схему позже.


person beast    schedule 15.07.2015    source источник


Ответы (2)


Лучший способ сделать это - использовать XSLT, вот небольшой пример, который я сделал для вас, поскольку вы видите, что все, что вам нужно сделать, это добавить в свой for каждый оператор, например, для сортировки по заголовку, для получения дополнительной информации перейдите сюда http://www.w3schools.com/xsl/el_sort.asp

    <?xml version="1.0" encoding="ISO-8859-1"?>
<catalog xmlns:foo="http://www.foo.org/" xmlns:bar="http://www.bar.org">
    <foo:cd>
        <title>Empire Burlesque</title>
        <artist>Bob Dylan</artist>
        <country>USA</country>
        <company>Columbia</company>
        <price>10.90</price>
        <bar:year>1985</bar:year>
    </foo:cd>
    <foo:cd>
        <title>Hide your heart</title>
        <artist>Bonnie Tyler</artist>
        <country>UK</country>
        <company>CBS Records</company>
        <price>9.90</price>
        <bar:year>1988</bar:year>
    </foo:cd>
    <foo:cd>
        <title>Greatest Hits</title>
        <artist>Dolly Parton</artist>
        <country>USA</country>
        <company>RCA</company>
        <price>9.90</price>
        <bar:year>1982</bar:year>
    </foo:cd>
</catalog>


<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:foo="http://www.foo.org/" xmlns:bar="http://www.bar.org">
<xsl:template match="/">
  <html>
  <body>
  <h2>My CD Collection</h2>
    <table border="1">
      <tr bgcolor="#9acd32">
        <th>Title</th>
        <th>Artist</th>
        <th>Country</th>
        <th>Company</th>
        <th>Price</th>
        <th>Year</th>
      </tr>
      <xsl:for-each select="catalog/foo:cd">
             <xsl:sort select="title"/>
      <tr>
        <td><xsl:value-of select="title"/></td>
        <td><xsl:value-of select="artist"/></td>
        <td><xsl:value-of select="country"/></td>
        <td><xsl:value-of select="company"/></td>
        <td><xsl:value-of select="price"/></td>
        <td><xsl:value-of select="bar:year"/></td>
      </tr>
      </xsl:for-each>
    </table>
  </body>
  </html>
</xsl:template>
</xsl:stylesheet>
person mahieddine    schedule 15.07.2015

Не встроен. Вам придется переназначить его (используя Custom XSLT) или загрузить его в XDocument и сохранить поверх исходного сообщения после использования каких-либо вызовов LINQ для его сортировки.

person Dan Field    schedule 15.07.2015