gpt4 book ai didi

带有排序的 XML 到 HTML 转换

转载 作者:行者123 更新时间:2023-12-04 05:22:12 25 4
gpt4 key购买 nike

以下是我需要转换的原始 XML 文件。这是一个音乐专辑记录列表,我必须将其转换为 HTML 表格,其中专辑按发行年份升序排列,我需要与每个单独的记录元素中包含的流派和唱片标签元素建立联系一个 id 引用并将它们输出到表中以及每个专辑。

在第二个转换中,我需要做的基本相同,但在这种情况下,输出应仅包含摇滚和流行流派的专辑。

    <?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type="text/xsl" href="zadacha1.xsl" ?>
<record_collection>
<genres>
<genre id="1">Rock</genre>
<genre id="2">Pop</genre>
<genre id="3">Disco</genre>
<genre id="4">Rap</genre>
<genre id="5">Electronic</genre>
<genre id="6">Country</genre>
</genres>

<record_labels>
<record_label id="1">DGC Records</record_label>
<record_label id="2">Atlantic</record_label>
<record_label id="3">Epic</record_label>
<record_label id="4">Warner Bros.</record_label>
<record_label id="5">EMI</record_label>
<record_label id="6">Columbia</record_label>
</record_labels>

<records>
<record>
<artist>Nirvana</artist>
<genreID>1</genreID>
<album>Nevermind</album>
<year_of_issue>1992</year_of_issue>
<record_labelID>1</record_labelID>
</record>

<record>
<artist>Twisted Sister</artist>
<genreID>1</genreID>
<album>Stay Hungry</album>
<year_of_issue>1984</year_of_issue>
<record_labelID>2</record_labelID>
</record>

<record>
<artist>Michael Jackson</artist>
<genreID>2</genreID>
<album>Thriller</album>
<year_of_issue>1982</year_of_issue>
<record_labelID>3</record_labelID>
</record>

<record>
<artist>Bee Gees</artist>
<genreID>3</genreID>
<album>Spirits Having Flown</album>
<year_of_issue>1979</year_of_issue>
<record_labelID>4</record_labelID>
</record>

<record>
<artist>Ice-T</artist>
<genreID>4</genreID>
<album>O.G. Original Gangster</album>
<year_of_issue>1991</year_of_issue>
<record_labelID>4</record_labelID>
</record>

<record>
<artist>Kraftwerk</artist>
<genreID>5</genreID>
<album>Computer World</album>
<year_of_issue>1981</year_of_issue>
<record_labelID>5</record_labelID>
</record>

<record>
<artist>Johnny Cash</artist>
<genreID>6</genreID>
<album>Man in Black</album>
<year_of_issue>1971</year_of_issue>
<record_labelID>6</record_labelID>
</record>

</records>
</record_collection>

我能管理的是输出一个没有流派和记录标签元素的未排序表,因为它们通过每个单独记录中的 id 链接,我不知道如何到达 id 并输出 id 后面的文本。这是我的 XSLT 转换到现在为止的内容。
<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

<xsl:template match="/record_collection/records">
<html>
<head>
<title>Records Collection</title>
</head>
<body>
<h1>Records Collection</h1>
<table border="1">
<tr>
<th>Genre</th>
<th>Artist</th>
<th>Album</th>
<th>Year</th>
<th>Label</th>
</tr>

<xsl:apply-templates select="record" />
</table>
<xsl:call-template name="footer" />
</body>
</html>
</xsl:template>

<xsl:template match="record">
<tr>
<td>?</td>
<td><xsl:value-of select="artist" /></td>
<td><xsl:value-of select="album" /></td>
<td><xsl:value-of select="year_of_issue" /></td>
<td>?</td>
</tr>
</xsl:template>


<xsl:template name="footer">
<div style="margin: 20px 0; padding: 10px; background-color: #efefef; ">
Record Collection
</div>
</xsl:template>

</xsl:stylesheet>

最佳答案

你只需要使用:

<xsl:apply-templates select="record">
<xsl:sort select="year_of_issue" order="ascending" data-type="number"/>
</xsl:apply-templates>

而不是
<xsl:apply-templates select="record"/>

该表将按发行年份升序排列

关于带有排序的 XML 到 HTML 转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13586232/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com