类型错误:';非类型';不支持缓冲区接口:使用XSLT转换XML时 相关的,我想感谢@ PaFaIT帮助我用当前的XSLT代码为我的项目开发XSLT基金会。然而,当我运行python模块时,我得到了一个错误 文件“nsnindex.py”,第17行,在 xmlfile.write(树输出) TypeError:“非类型”不支持缓冲区接口。
总体计划是XPATH直接转到第三个子节点类型错误:';非类型';不支持缓冲区接口:使用XSLT转换XML时 相关的,我想感谢@ PaFaIT帮助我用当前的XSLT代码为我的项目开发XSLT基金会。然而,当我运行python模块时,我得到了一个错误 文件“nsnindex.py”,第17行,在 xmlfile.write(树输出) TypeError:“非类型”不支持缓冲区接口。,python,xml,xslt,xpath,nonetype,Python,Xml,Xslt,Xpath,Nonetype,总体计划是XPATH直接转到第三个子节点 <national_stock_number_cross_reference_index> 输出 5310 00-880-5978 有人知道我做错了什么吗?是我的XPATH吗@Parfait的程序在根标记仅为时工作,但在我更改路径以匹配更复杂的文件后,它就停止正常工作。XML中出现了两个影响XSLT转换的问题: 未声明的命名空间前缀(xmlns=“place2”),其中标头中的xmlns特殊属性没有冒号分隔的标识符。因此,XSLT必须声
<national_stock_number_cross_reference_index>
输出
5310
00-880-5978
有人知道我做错了什么吗?是我的XPATH吗@Parfait的程序在根标记仅为
时工作,但在我更改路径以匹配更复杂的文件后,它就停止正常工作。XML中出现了两个影响XSLT转换的问题:
xmlns=“place2”
),其中标头中的xmlns特殊属性没有冒号分隔的标识符。因此,XSLT必须声明前缀national\u stock\u number\u cross\u reference\u index
元素。因此,XSLT必须使用其他模板doc
前缀,该前缀在所有其他XPath表达式中都是前缀。使用相同的Python代码进行处理
XSLT
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:doc="place2" exclude-result-prefixes="doc">
<xsl:output method="xml" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:key name="numkey" match="doc:national_stock_number_cross_reference"
use="concat(doc:federal_supply_classification, doc:national_item_identification_number)"/>
<xsl:template match="/doc:lsar030">
<xsl:apply-templates select="doc:head"/>
<xsl:apply-templates seect="doc:body"/>
</xsl:template>
<xsl:template match="doc:head"/>
<xsl:template match="doc:body">
<xsl:apply-templates select="doc:national_stock_number_cross_reference_index"/>
</xsl:template>
<xsl:template match="doc:national_stock_number_cross_reference_index">
<nsnindxrows>
<xsl:apply-templates select="doc:national_stock_number_cross_reference[generate-id() =
generate-id(key('numkey', concat(doc:federal_supply_classification, doc:national_item_identification_number))[1])]"/>
<nsnindxrows>
</xsl:template>
<xsl:template match="doc:national_stock_number_cross_reference">
<nsnindxrow>
<nsn>
<fsc><xsl:value-of select="doc:federal_supply_classification"/></fsc>
<niin><xsl:value-of select="doc:national_item_identification_number"/></niin>
</nsn>
<xsl:for-each select="key('numkey', concat(doc:federal_supply_classification, doc:national_item_identification_number))">
<callout>
<xsl:attribute name="assocfig"><xsl:value-of select="concat('fig', doc:figure_number)"/></xsl:attribute>
<xsl:attribute name="label"><xsl:value-of select="doc:item_number"/></xsl:attribute>
</callout>
</xsl:for-each>
</nsnindxrow>
</xsl:template>
</xsl:stylesheet>
输出
(与前面问题的XML不同,由于XML是
和
的一对,因此只呈现一个标注)
1234
000000000
1235
111111111
1236
212121212
更完整更好的示例XML文件,我认为您有一个未定义的名称空间前缀。很高兴听到!很乐意帮忙。在将来,总是发布示例XML的顶部标题,包括标题行和根标记,因为它们携带重要信息。xslt仍然在标题位置吐出信息,这有什么原因吗。它不会对给定的输入执行此操作,因为我删除了数据。但是,当标签被填写时。输出的顶部包含所有标题信息。我可能会在以后使用一些信息,但是我应该如何开始修补标题信息呢?我不明白。什么标签?什么头球?这个:
?同样,如果您使用的XML与此处发布的XML不同,XSLT的工作原理可能不一样。我的错误。输出没有显示任何这些。然而,我的pythonshell显示了文件中的所有,但是输出文件只编写了第一行。我将调整输入以包含更多的NSNindex行。请参阅更新的XSLT,在其中我将根添加到输出:…
。
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:key name="numkey" match="lsar030/body/national_stock_number_cross_reference_index/national_stock_number_cross_reference"
use="concat(federal_supply_classification, national_item_identification_number)"/>
<xsl:template match="lsar030/body/national_stock_number_cross_reference_index">
<xsl:apply-templates select="national_stock_number_cross_reference[generate-id() =
generate-id(key('numkey', concat(federal_supply_classification, national_item_identification_number))[1])]"/>
</xsl:template>
<xsl:template match="lsar030/body/national_stock_number_cross_reference_index/national_stock_number_cross_reference">
<nsnindxrow>
<nsn>
<fsc><xsl:value-of select="federal_supply_classification"/></fsc>
<niin><xsl:value-of select="national_item_identification_number"/></niin>
</nsn>
<xsl:for-each select="key('numkey', concat(federal_supply_classification, national_item_identification_number))">
<callout>
<xsl:attribute name="assocfig"><xsl:value-of select="concat('fig', figure_number)"/></xsl:attribute>
<xsl:attribute name="label"><xsl:value-of select="item_number"/></xsl:attribute>
</callout>
</xsl:for-each>
</nsnindxrow>
</xsl:template>
</xsl:stylesheet>
import lxml.etree as ET
# LOAD XML AND XSL FILES
dom = ET.parse('lsar030.xml')
xslt = ET.parse('XSLTScript.xsl')
# TRANSFORM SOURCE
transform = ET.XSLT(xslt)
newdom = transform(dom)
print(newdom)
# OUTPUT TRANSFORMED TREE TO STRING
tree_out = ET.tostring(newdom, encoding='UTF-8', pretty_print=True, xml_declaration=True)
# OUTPUT STRING TO FILE
xmlfile = open('Output.xml', 'wb')
xmlfile.write(tree_out)
xmlfile.close()
<nsnindxrow>
<nsn>
<fsc>5310</fsc>
<niin>00-880-5978</niin>
</nsn>
<callout assocfig="fig700" label="34">
<callout assocfig="fig701" label="10">
<callout assocfig="fig703" label="9">
</nsnindxrow>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:doc="place2" exclude-result-prefixes="doc">
<xsl:output method="xml" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:key name="numkey" match="doc:national_stock_number_cross_reference"
use="concat(doc:federal_supply_classification, doc:national_item_identification_number)"/>
<xsl:template match="/doc:lsar030">
<xsl:apply-templates select="doc:head"/>
<xsl:apply-templates seect="doc:body"/>
</xsl:template>
<xsl:template match="doc:head"/>
<xsl:template match="doc:body">
<xsl:apply-templates select="doc:national_stock_number_cross_reference_index"/>
</xsl:template>
<xsl:template match="doc:national_stock_number_cross_reference_index">
<nsnindxrows>
<xsl:apply-templates select="doc:national_stock_number_cross_reference[generate-id() =
generate-id(key('numkey', concat(doc:federal_supply_classification, doc:national_item_identification_number))[1])]"/>
<nsnindxrows>
</xsl:template>
<xsl:template match="doc:national_stock_number_cross_reference">
<nsnindxrow>
<nsn>
<fsc><xsl:value-of select="doc:federal_supply_classification"/></fsc>
<niin><xsl:value-of select="doc:national_item_identification_number"/></niin>
</nsn>
<xsl:for-each select="key('numkey', concat(doc:federal_supply_classification, doc:national_item_identification_number))">
<callout>
<xsl:attribute name="assocfig"><xsl:value-of select="concat('fig', doc:figure_number)"/></xsl:attribute>
<xsl:attribute name="label"><xsl:value-of select="doc:item_number"/></xsl:attribute>
</callout>
</xsl:for-each>
</nsnindxrow>
</xsl:template>
</xsl:stylesheet>
<?xml version="1.0"?>
<nsnindxrows>
<nsnindxrow>
<nsn>
<fsc>1234</fsc>
<niin>000000000</niin>
</nsn>
<callout assocfig="fig1" label="1"/>
<callout assocfig="fig2" label="4"/>
<callout assocfig="fig3" label="2"/>
</nsnindxrow>
<nsnindxrow>
<nsn>
<fsc>1235</fsc>
<niin>111111111</niin>
</nsn>
<callout assocfig="fig1" label="1"/>
<callout assocfig="fig2" label="3"/>
</nsnindxrow>
<nsnindxrow>
<nsn>
<fsc>1236</fsc>
<niin>212121212</niin>
</nsn>
<callout assocfig="fig2" label="3"/>
</nsnindxrow>
</nsnindxrows>