结果

结果

我正在尝试将 RSS 源中某些元素的值输出为列。相关 RSS 源的结构如下(缩写):

$ xmlstarlet el ~/tmp/spotn-rss-20140323 | sort -u 

rss/channel/title
rss/channel/item/content
rss/channel/item/description
rss/channel/item/link
rss/channel/item/pubDate
rss/channel/item/title

在应用带有模板的 xmlstarlet sel 命令后,我希望看到按列排列的项目标题列表及其发布日期。

$ xmlstarlet sel -t \
    -v rss/channel/item/title \
    -v rss/channel/item/pubDate -n ~/tmp/spotn-rss-20140323

Desired output:               Actual output:

title1:pubDate1               title1
title2:pubDate2               title2
title3:pubDate3               title3
 (...)                         (...)
                              pubDate1
                              pubDate2
                              pubDate3
                               (...)

这个问题看起来相当简单,我认为检查一下可能是个好主意用户指南事实证明,带有 .xls 样式表的 hello world 示例提供了轻松实现所需效果的方法:

<?xml version="1.0"?>
<xsl:stylesheet version="1.0"
     xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"/>
<xsl:param name="inputFile">-</xsl:param>
<xsl:template match="/">
  <xsl:call-template name="t1"/>
</xsl:template>
<xsl:template name="t1">
    <xsl:for-each select="rss/channel/item">
    <xsl:value-of select="title" />^<xsl:value-of select="pubDate" />;
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>

我使用转换命令获得了所需的输出,但我发现这种方法相当麻烦,因为 xml/xls 非常啰嗦。我的目标是快速查看 xml 中的某些元素,我不想为此编写一个约 450 个字符的样式表。

$ xmlstarlet tr  /home/jaroslav/tmp/spotn-rss-style.xls \
          /home/jaroslav/tmp/spotn-rss-20140323 |
  column -ts^

Test                                         Thu, 20 Mar 2014 18:58:11 +0000;
Assisterende borer – Songa Offshore          Thu, 20 Mar 2014 12:48:03 +0000;
Maskinsjef                                   Thu, 20 Mar 2014 10:23:16 +0000;
Maskinsjefer/Motorpassere                    Sun, 16 Mar 2014 16:37:15 +0000;
Skipsfører                                   Sun, 16 Mar 2014 16:30:19 +0000;
Tilkallingsvikarar matros                    Thu, 13 Mar 2014 03:15:55 +0000;
Matros                                       Wed, 12 Mar 2014 13:05:57 +0000;
1. styrmann                                  Tue, 11 Mar 2014 05:44:31 +0000;
Overstyrmann Scan Trans                      Tue, 04 Mar 2014 06:35:29 +0000;
(...)

如果有一种方法可以将每个<item>元素的两个值连接到<channel>单独的行上,而无需借助 xls 样式表或外部流编辑器(如 sed 和 awk),那将是最有用的。

答案1

xls 样式表提供了线索。

原始示例样式表有 ,xsl:for-each select="/"而问题中的样式表有
select="rss/channel/item"。使用相同的逻辑,只需匹配 rss/channel/item 并使用分隔符打印每个 title、pubDate:

$ xmlstarlet sel -t           \
     -m rss/channel/item      \
        -v title -o '^'       \
        -v pubDate            \
        -n ~/tmp/spotn-rss-20140323 |
  column -ts^

结果

 Test                                          Thu, 20 Mar 2014 18:58:11 +0000
 Assisterende borer – Songa Offshore           Thu, 20 Mar 2014 12:48:03 +0000
 Borer – Boring – Songa Offshore               Thu, 20 Mar 2014 12:42:57 +0000
 Hydrauliker – Songa Offshore                  Thu, 20 Mar 2014 12:34:56 +0000

相关内容