gpt4 book ai didi

excel - 具有默认命名空间的 XML::LibXML

转载 作者:行者123 更新时间:2023-12-04 21:32:28 34 4
gpt4 key购买 nike

我有一个 XML 文件,如下

示例.xml

<?xml version="1.0"?>
<Workbook xmlns='urn:schemas-microsoft-com:office:spreadsheet'>
<id>test</id>
</Workbook>

以下代码未找到 id 标记值:

use XML::LibXML;

my $filename = 'example.xml';

my $dom = XML::LibXML->load_xml( location => $filename );
my $xpc = XML::LibXML::XPathContext->new($dom);
my $match1 = $xpc->findnodes('//id');

print "XPath $match1\n";

但是如果我删除默认 namespace 定义并将其替换为以下行:

<Workbook>

然后就可以了。

如何读取定义了默认命名空间的标签?

最佳答案

这里有两件事你需要知道

  • XML 中使用的命名空间前缀不需要与 XPath 查询中使用的任何前缀匹配;只需要对应的URN相同即可

  • 无法在 XPath 中定义“默认”命名空间

这意味着在 XML 中声明的没有前缀的命名空间必须在 XPath 表达式中给出前缀

这段代码看起来是正确的,但我目前无法测试它。请确保在您编写的每个 Perl 程序的顶部始终使用严格使用警告“all”

use strict;
use warnings 'all';

use XML::LibXML;

my $filename = 'example.xml';

my $dom = XML::LibXML->load_xml( location => $filename );
my $xpc = XML::LibXML::XPathContext->new( $dom );
$xpc->registerNs( mss => 'urn:schemas-microsoft-com:office:spreadsheet' );
my $match1 = $xpc->findnodes('//mss:id');

print "XPath $match1\n";

关于excel - 具有默认命名空间的 XML::LibXML,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48379738/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com