- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我想将 XML 文件转换为 CSV 文件。我要导出的字段是 <issues>
.每个问题都有一组标准字段和一些自定义字段。可能的自定义字段在 <issue-custom-fields>
中定义.不是每个 <issue>
已设置所有自定义字段。对于 CSV 导出,我必须为每个缺失的条目添加一个空字段 ( ",,"
)。我该怎么做?
以下 xslt 文件循环遍历所有问题字段和所有自定义字段。而不是“字段值”?我想在当前项目中查找相应的字段值(如果存在,则为空白)。
XSLT 版本应为 1.0。
<xsl:transform xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="text" />
<xsl:template match="/">
<xsl:apply-templates select="xml_data/issues"/>
</xsl:template>
<xsl:template match="issue">
<xsl:for-each select="*">
<xsl:choose>
<xsl:when test="name(.) = 'custom-values'">
<xsl:for-each select="/xml_data/issue-custom-fields/issue-custom-field">
<xsl:variable name="f" select="id" />
<xsl:text>field value?</xsl:text>
<xsl:if test="position() != last()">
<xsl:text>,</xsl:text>
</xsl:if>
</xsl:for-each>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="."/>
<xsl:if test="position() != last()">
<xsl:text>,</xsl:text>
</xsl:if>
</xsl:otherwise>
</xsl:choose>
</xsl:for-each>
</xsl:template>
</xsl:transform>
作用于以下数据:
<?xml version="1.0" encoding="UTF-8"?>
<xml_data>
<projects type="array">
<project>
<id type="integer">10</id>
<name>Helpdesk</name>
<type>open</type>
</project>
<project>
<id type="integer">20</id>
<name>Development</name>
<type>closed</type>
</project>
</projects>
<issue-custom-fields>
<issue-custom-field>
<id>1000</id>
<name>Delay</name>
</issue-custom-field>
<issue-custom-field>
<id>1001</id>
<name>Means of Delivery</name>
</issue-custom-field>
<issue-custom-field>
<id>1002</id>
<name>Shipping Date</name>
</issue-custom-field>
</issue-custom-fields>
<issues type="array">
<issue>
<id type="integer">100</id>
<project-id type="integer">10</project-id>
<subject>first helpdesk issue</subject>
<description>a small problem</description>
<custom-values>
<custom-value>
<custom-field-id>1000</custom-field-id>
<value>15</value>
</custom-value>
<custom-value>
<custom-field-id>1002</custom-field-id>
<value>2016-08-01</value>
</custom-value>
</custom-values>
</issue>
<issue>
<id type="integer">101</id>
<project-id type="integer">10</project-id>
<subject>second helpdesk issue</subject>
<description>a medium problem</description>
<custom-values>
<custom-value>
<custom-field-id>1000</custom-field-id>
<value>10</value>
</custom-value>
<custom-value>
<custom-field-id>1001</custom-field-id>
<value>FTP</value>
</custom-value>
</custom-values>
</issue>
<issue>
<id type="integer">102</id>
<project-id type="integer">10</project-id>
<subject>third helpdesk issue</subject>
<description>a huge security problem</description>
<custom-values>
<custom-value>
<custom-field-id>1001</custom-field-id>
<value>SSH</value>
</custom-value>
</custom-values>
</issue>
<issue>
<id type="integer">103</id>
<project-id type="integer">20</project-id>
<subject>first "development" issue</subject>
<description>just some "strange" software</description>
<custom-values>
</custom-values>
</issue>
</issues>
</xml_data>
非常感谢您的帮助。
最佳答案
如果我没理解错的话,你想做的是:
XSLT 1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text" encoding="UTF-8"/>
<xsl:key name="custom-value" match="custom-value" use="concat(custom-field-id, '|', ancestor::issue/id)" />
<xsl:template match="/xml_data">
<xsl:variable name="custom-fields" select="issue-custom-fields/issue-custom-field" />
<!-- header -->
<!-- standard fields -->
<xsl:for-each select="issues/issue[1]/*[not(self::custom-values)]">
<xsl:value-of select="name()"/>
<xsl:text>,</xsl:text>
</xsl:for-each>
<!-- custom fields -->
<xsl:for-each select="$custom-fields">
<xsl:value-of select="name"/>
<xsl:if test="position() != last()">
<xsl:text>,</xsl:text>
</xsl:if>
</xsl:for-each>
<xsl:text> </xsl:text>
<!-- data -->
<xsl:for-each select="issues/issue">
<xsl:variable name="issue-id" select="id" />
<!-- standard fields -->
<xsl:for-each select="*[not(self::custom-values)]">
<xsl:value-of select="."/>
<xsl:text>,</xsl:text>
</xsl:for-each>
<!-- custom fields -->
<xsl:for-each select="$custom-fields">
<xsl:value-of select="key('custom-value', concat(id, '|', $issue-id))/value"/>
<xsl:if test="position() != last()">
<xsl:text>,</xsl:text>
</xsl:if>
</xsl:for-each>
<xsl:text> </xsl:text>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
应用于您的输入示例,结果将是:
id,project-id,subject,description,Delay,Means of Delivery,Shipping Date
100,10,first helpdesk issue,a small problem,15,,2016-08-01
101,10,second helpdesk issue,a medium problem,10,FTP,
102,10,third helpdesk issue,a huge security problem,,SSH,
103,20,first "development" issue,just some "strange" software,,,
关于xml - 在 xslt 模板中创建 key ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38779288/
我有一个 XSLT 样式表,如下所示: 我想使用第二个 XSLT 样式表来转换此样式表,以删除与 XQHead
我们有一个大型 xslt,可以呈现整个商店区域,包括产品、制造商,并根据价格和类别进行过滤。我使用 sitecore 作为 CMS,但遇到缓存问题。我有大约 9000 个项目,有些页面需要长达 20
我想根据条件的结果应用具有不同参数的模板。像这样: Attribute no. 1
我有一些看起来像这样的 XML Foo Details Bar Details Baz Details Foo Blah Bar BlahBlah Baz BlahBlahBl
我试图从这种输入出发: a b c d e f g ... 使用 XSLT 的 HTML 输出: one two a e b f
我想知道如何在 xslt 中找到特定节点的第一个子节点名称。 我有一个 xml: some text 我可以使用 body/
是否可以在 XSLT 中获取上个月的最后一天?我找到了这个函数:http://www.xsltfunctions.com/xsl/functx_last-day-of-month.html但我不确定如
具有特定节点的匹配元素存在问题。 xml: description of profile PhoneKeyPad S
我将一堆键值对作为参数传递给 XSL(日期 ->“1 月 20 日”,作者 ->“Dominic Rodger”,...)。 我正在解析的一些 XML 中引用了这些 - XML 如下所示: 目前,除
我找不到这个问题的确切答案,所以我希望有人能在这里帮助我。 我有一个字符串,我想在最后一个 '.' 之后获取子字符串。我正在使用 xslt 1.0。 这是怎么做的?这是我的代码。
我在尝试找出 xslt 上的 var 范围时遇到问题。我实际上想要做的是忽略具有重复“旅游代码”的“旅行”标签。 示例 XML: X1 Budapest X1 Budapest X
我有一些数据在 xslt 的 for-each 循环中输出。我对列表进行了分页,但没有对排序选择器进行分页。 用户应该能够对 2 个值(创建的数据和每个项目的数字字段)进行排序。默认的排序方法是创建日
我有一个奇怪的要求。 我在 xslt 中有一个包含月份的变量,带有它们的 id (1-12) 问题是我需要全部显示它们,但从一月(1)以外的月份开始。 目前我有以下 JAN
如何在 xslt 转换中模块化一组重复的输出?例如,我有如下内容(伪代码)。 并
我得到一个像这样的字符串。 13091711111100222222003333330044444400 字符串的模式是这样的 13 - 09 - 17 - 11111 - 100 - 22222 -
我是 XSLT 的新手,有一个一般性问题。为了区分具有不同属性的两个元素,最好(也是为了性能)使用 和 而不是 在一个模板中。据我所知,这就是 XSLT 中应该“思考”的方式。但在我看来,这有一个缺点
如何从“19650512-0065”到“196505120065”这样的字符串中删除连字符 使用这个模板:传递 theID =
是否有任何功能可以在左侧填充零? 我正在尝试做的要求是: 我们不知道即将到来的输入字符串长度。 如果小于 20,我们必须在左侧填充零。 如果输入字符串长度为 10,那么我们必须在左侧填充 10 个零。
身份模板如下所示: 是否选择多于 ,或者身份模板可能是这样的? 当我执行以下操作时,究竟选择了什么? 最佳答案
我正在尝试使用 XML 信息和 XSLT 模板创建超链接。这是 XML 源代码。 Among individual stocks, the top percentage gainers in the
我是一名优秀的程序员,十分优秀!