6

我是 stackoverflow 和 xslt 的菜鸟,所以我希望我不会听起来不聪明!

因此,我正在与一家 GIS 公司的 SDI 合作,我有一项任务要求我将位于一个空间参考系统 (SRS) 坐标平面中的点(例如 EPSG:4035)转换为世界 SRS,即 EPSG:4326。这对我来说真的不是问题,因为我可以使用在线服务,它只会给我想要的东西。但是,它输出的格式是 JSON 或 HTML。我已经浏览了一段时间以找到一种从 JSON 文件中提取信息的方法,但是我看到的大多数技术都使用 xslt:stylesheet 2.0 版,我必须使用 1.0 版。我考虑过的一种方法是使用 document($urlWithJsonFormat) xslt 函数,但是这只接受 xml 文件。

下面是一个 JSON 格式文件的示例,我在请求转换后将检索该文件:

{
  “几何”:
  [{
      “xmin”:-4,
      “ymin”:-60,
      “最大”:25,
      “最大”:-41
    }
  ]
}

我只想要 xmin、ymin、xmax 和 ymax 值,仅此而已!它看起来很简单,但对我没有任何作用......

4

2 回答 2

4

您可以使用外部实体将 JSON 数据作为 XML 文件的一部分包含在内,然后进行转换。

例如,假设示例 JSON 保存为名为“geometries.json”的文件,您可以创建如下 XML 文件:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE wrapper [
<!ENTITY otherFile SYSTEM "geometries.json">
]>
<wrapper>&otherFile;</wrapper>

然后使用以下 XSLT 1.0 样式表对其进行转换:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:output omit-xml-declaration="yes" indent="yes"/>

<xsl:template match="wrapper">
    <geometries>
        <xsl:call-template name="parse-json-member-value">
            <xsl:with-param name="member" select="'xmin'"/>
        </xsl:call-template>
        <xsl:call-template name="parse-json-member-value">
            <xsl:with-param name="member" select="'ymin'"/>
        </xsl:call-template>
        <xsl:call-template name="parse-json-member-value">
            <xsl:with-param name="member" select="'xmax'"/>
        </xsl:call-template>
        <xsl:call-template name="parse-json-member-value">
            <xsl:with-param name="member" select="'ymax'"/>
        </xsl:call-template>
    </geometries>
</xsl:template>

    <xsl:template name="parse-json-member-value">
        <xsl:param name="member"/>
        <xsl:element name="{$member}">
            <xsl:value-of select="normalize-space(
                                    translate(
                                        substring-before(
                                            substring-after(
                                                substring-after(.,
                                                    concat('&quot;', 
                                                           $member, 
                                                          '&quot;'))
                                                , ':')
                                            ,'&#10;')
                                    , ',', '')
                                  )"/>
        </xsl:element>
    </xsl:template>
</xsl:stylesheet>

产生以下输出:

<geometries>
   <xmin>-4</xmin>
   <ymin>-60</ymin>
   <xmax>25</xmax>
   <ymax>-41</ymax>
</geometries>
于 2012-08-30T02:37:44.683 回答
1

这里的两个主要选择似乎是:

  1. 在 XSLT 1.0 中编写(或使用)JSON 解析器,或
  2. 使用 XSLT 以外的其他语言。

由于 XSLT 1 引擎通常不能直接处理 JSON,我建议使用其他语言来转换为 XML。

https://github.com/WelcomWeb/JXS也可能对您有所帮助,如果这是 Web 浏览器中的 XSLT。

于 2012-08-30T02:28:01.667 回答