使用XPath查询读取文件XML



早上好我需要推断出一系列的值​​通过我在页面末尾报告的XML文件中的XPath查询。

我能够获得这些值​​直到模式的FileGroup级别,例如使用//FileGroup/File/Path 这样的查询

但是,我无法读取EmbeddedMetadata节点中包含的数据

我尝试过各种方式,例如//FileGroup/File/MoreInfo/EmbeddedMetadata/SubjectDestinatario/Denominazione和其他人,但我没有得到正确的查询特别是,对我来说,阅读标签中包含的值会很有用,例如:

<FileNameOriginale> IT09533610011_173.xml </FileNameOriginale>
<SubjectDestinatario role = "Addressee" type = "organization">
<Denomination> REWIND Srl </Denomination>
<MetadataAggiuntivi name = "NumeroDocumento"
value = "2020047"

正是在这种情况下,我想阅读:IT09533610011_173.xmlREWIND Srl2020047

提前非常感谢你,谁会好心帮助我

<?xml version="1.0" encoding="utf-8"?>
<SIP url="http://www.archismall.com" version="1.0" xmlns:s="http://www.uni.com/U3011/sincro/">
<SelfDescription>
<ID s:scheme="local">IDVc9df21aa-f2f9-4345-a580-c8f777367adc1</ID>
<CreatingApplication>
<Name>ArchiSMALL</Name>
<Version>1.12.2</Version>
<Producer>Archivist SRL</Producer>
</CreatingApplication>
</SelfDescription>
<VdV>
<ID s:scheme="local">SIPc9df21aa-f2f9-4345-a580-c8f777367adc</ID>
</VdV>
<FileGroup>
<File encoding="binary" format="text/xml">
<ID s:scheme="local">a6b72ff7-4287-4f56-96d8-1da9a89d2316</ID>
<Path>document/1/IT09533610011_173.xml</Path>
<Hash function="SHA-256">6fb942e36b879764cb5cf95a2bffa3585f7f04155447ccc38d38441ed7dd6852</Hash>
<MoreInfo xmlns="http://archismall.com/IDV_EmbeddedMetadata_XSD.xsd">
<EmbeddedMetadata>
<FileNameOriginale>IT09533610011_173.xml</FileNameOriginale>
<IdDocumento s:scheme="local">a6b72ff7-4287-4f56-96d8-1da9a89d2316</IdDocumento>
<ImprontaDocumento function="SHA-256">6fb942e36b879764cb5cf95a2bffa3585f7f04155447ccc38d38441ed7dd6852</ImprontaDocumento>
<OggettoDocumento>Fattura Elettronica Passiva</OggettoDocumento>
<DataChiusura normal="+01">2021-01-07 12:41:38</DataChiusura>
<SoggettoProduttore role="Producer" type="organization">
<Denominazione>GEFIR IMMOBILIARE S.R.L.</Denominazione>
<PartitaIva scheme="VATRegistrationNumber">09533610011</PartitaIva>
<CodiceFiscale scheme="TaxCode">09533610011</CodiceFiscale>
</SoggettoProduttore>
<SoggettoDestinatario role="Addressee" type="person">
<Nome>Mario</Nome>
<Cognome>Infanti</Cognome>
<CodiceFiscale scheme="TaxCode">NFNMRA46R09F463G</CodiceFiscale>
</SoggettoDestinatario>
<SoggettoDestinatario role="Addressee" type="organization">
<Denominazione>REWIND Srl</Denominazione>
<PartitaIva scheme="VATRegistrationNumber"/>
<CodiceFiscale scheme="TaxCode">02406910352</CodiceFiscale>
</SoggettoDestinatario>
<MetadataAggiuntivi name="PeriodoEsercizio"
value="2020" xmlns="http://archismall.com/Metadata.xsd"/>
<MetadataAggiuntivi name="NumeroDocumento"
value="2020047" xmlns="http://archismall.com/Metadata.xsd"/>
<MetadataAggiuntivi name="DataDocumento"
value="2020-12-31" xmlns="http://archismall.com/Metadata.xsd"/>
<MetadataAggiuntivi name="TipoDocumento"
value="Fattura" xmlns="http://archismall.com/Metadata.xsd"/>
<MetadataAggiuntivi name="ProgressivoInvio"
value="173" xmlns="http://archismall.com/Metadata.xsd"/>
<MetadataAggiuntivi name="ResponsabileConservazione"
value="Mario Infanti" xmlns="http://archismall.com/Metadata.xsd"/>
</EmbeddedMetadata>
</MoreInfo>
</File>
</FileGroup>
<Process>
<Agent role="Producer" type="person">
<AgentName>
<NameAndSurname>
<FirstName>Mario</FirstName>
<LastName>Infanti</LastName>
</NameAndSurname>
</AgentName>
<Agent_ID scheme="TaxCode">NFNMRA46R09F463G</Agent_ID>
</Agent>
<Agent role="Producer" type="organization">
<AgentName>
<FormalName>REWIND Srl</FormalName>
</AgentName>
<Agent_ID scheme="TaxCode">02406910352</Agent_ID>
</Agent>
<TimeReference>
<TimeInfo normal="+01">2021-01-07 12:41:38</TimeInfo>
</TimeReference>
</Process>
</SIP>

如果是XPath 1,那么学习如何将前缀(例如idv(绑定到环境中的命名空间http://archismall.com/IDV_EmbeddedMetadata_XSD.xsd,然后像在例如//idv:MoreInfo/idv:EmbeddedMetadata/idv:FileNameOriginale中那样使用它来选择该命名空间中的元素,或者选择本地名称,例如//*[local-name() = 'MoreInfo']/*[local-name() = 'EmbeddedMetadata']/*[local-name() = 'FileNameOriginale']

对于XPath2或3,可以始终使用命名空间通配符,例如//*:MoreInfo/*:EmbeddedMetadata/*:FileNameOriginale用于命名空间中的那些元素。在XPath3中,您甚至可以在路径的每个步骤中包括名称空间URI,例如Q{http://archismall.com/IDV_EmbeddedMetadata_XSD.xsd}EmbeddedMetadata

首先感谢您的友好回复我有一个软件应用程序,必须通过输入正确的xpath查询来设置它,以获得稍后将写入数据库的数据的提取这个软件还允许你声明名称空间,但事实上我不知道如何管理这个功能,所以如果可能的话,我宁愿不使用它为了回答David的问题,不幸的是,我不知道这个应用程序能支持什么级别的Xpath,据我所知,我可以说它采用了与以下链接中的Xpath测试人员支持的语法相同的语法

https://codebeautify.org/Xpath-Tester

我在测试人员中尝试在这个XML文件上使用建议的字符串,我写了

*:更多信息/*:嵌入的元数据/*:原始文件名

但显然没有成功,因为我没有返回任何价值

也许我在写查询的时候犯了一个错误?

也许根据所提供的信息,你能给我进一步的帮助吗?

非常感谢

我确认问题已经解决,尤其是在我的情况下,这种查询结构对我很有用:

//[local-name((='MoreInfo']/[local-name(

使用相同的语法,即使没有指定名称空间,我也可以获得EmbeddedMetadata组的更多数据

还可以使用以下表达式读取后续节点,例如:

//*[local-name((="附加元数据"][@name="文档编号"]/@value

非常感谢大家对的宝贵帮助

朋友们玩得愉快

再见

相关内容

  • 没有找到相关文章

最新更新