簡體   English   中英

如何將 MARC21-xml 轉換和過濾為 csv?

[英]How to transform and filter a MARC21-xml into csv?

根據 MARC21 格式,我有 xml 文件,如下所示:

(它被減少到必要的標簽,文件有很多records我只減少到一個)

<?xml version="1.0" encoding="UTF-8"?>
<collection xmlns="http://www.loc.gov/MARC21/slim">
<record>
  <controlfield tag="001">EntryID01</controlfield>
  <datafield tag="100" ind1="1" ind2=" ">
    <subfield code="0">PubID01</subfield>
    <subfield code="a">Lastname01, Firstname01</subfield>
  </datafield>
  <datafield tag="700" ind1="1" ind2=" ">
    <subfield code="0">PubID02</subfield>
    <subfield code="a">Lastname02, Firstname02</subfield>
  </datafield>
  <datafield tag="700" ind1="1" ind2=" ">
    <subfield code="a">Lastname03, Firstname03</subfield>
  </datafield>
</record>
</collection>

我想得到一個 csv 具有以下順序/輸出。

Lastname01, Firstname01 | PubID01 | EntryID01
Lastname02, Firstname02 | PubID02 | EntryID01
Lastname03, Firstname03 | NOPUBID | EntryID01

並非所有數據字段都有 PubID 的信息( subfield code="0" ),如果沒有給定的 PubID,則應改為“NOPUBID”。

我的嘗試是將xsltproc與此xsl一起使用:(我試圖先從tag=100獲取數據;但我也需要從tag=700獲取數據)

<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:marc="http://www.loc.gov/MARC21/slim"
xmlns="http://www.loc.gov/MARC21/slim"
exclude-result-prefixes="marc">
<xsl:output method="text" encoding="UTF-8" />
<xsl:strip-space elements="*"/>
    <xsl:template match="marc:controlfield[@tag=001]">
            <xsl:value-of select="controlfield"/>
    </xsl:template>
    <xsl:template match="marc:datafield[@tag=100]">
        <xsl:for-each select="record/datafield">
            <xsl:value-of select="controlfield"/>
        </xsl:for-each>
    </xsl:template>
</xsl:stylesheet>

但我絕望地失敗了。 任何幫助表示贊賞。

我會做:

XSLT 1.0

<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
xmlns:marc="http://www.loc.gov/MARC21/slim">
<xsl:output method="text" encoding="UTF-8"/>

<xsl:template match="/marc:collection">
    <xsl:for-each select="marc:record">
        <xsl:variable name="control" select="marc:controlfield[@tag='001']" />
        <xsl:for-each select="marc:datafield[@tag='100' or @tag='700']">
            <xsl:value-of select="marc:subfield[@code='a']"/>
            <xsl:text> | </xsl:text>
            <xsl:variable name="pub" select="marc:subfield[@code='0']"/>
            <xsl:choose>
                <xsl:when test="$pub">
                    <xsl:value-of select="$pub"/>
                </xsl:when>
                <xsl:otherwise>NOPUBID</xsl:otherwise>
            </xsl:choose>
            <xsl:text> | </xsl:text>
            <xsl:value-of select="$control"/>
            <xsl:text>&#10;</xsl:text>
        </xsl:for-each>
    </xsl:for-each>
</xsl:template>

</xsl:stylesheet>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM