- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我有一些示例 XML,我在其中查询基于日期的节点。
示例 XML 文档:
<?xml version="1.0" encoding="UTF-16" standalone="yes"?>
<NewDataSet>
<Table>
<EmployeeBankGUID>dc396ebe-c8a4-4a7f-85b5-b43c1890d6bc</EmployeeBankGUID>
<ValidFromDate>2012-02-01T00:00:00-05:00</ValidFromDate>
</Table>
<Table>
<EmployeeBankGUID>2406a5aa-0246-4cd7-bba5-bb17a993042b</EmployeeBankGUID>
<ValidFromDate>2013-02-01T00:00:00-05:00</ValidFromDate>
</Table>
<Table>
<EmployeeBankGUID>2af49699-579e-4beb-9ab0-a58b4bee3158</EmployeeBankGUID>
<ValidFromDate>2014-02-01T00:00:00-05:00</ValidFromDate>
</Table>
</NewDataSet>
所以基本上有三个日期:
使用 MSXML,我可以使用 XPath 查询按这些日期进行查询和过滤:
/NewDataSet/Table[ValidFromDate>"2013-02-12"]
这有效,并返回 IXMLDOMNodeList
包含一项:
<Table>
<EmployeeBankGUID>2af49699-579e-4beb-9ab0-a58b4bee3158</EmployeeBankGUID>
<ValidFromDate>2014-02-01T00:00:00-05:00</ValidFromDate>
</Table>
使用 MSXML 的 XPath 查询;在 W3C 对完全不同形式的 XPath 进行标准化之前,Microsoft 在 1990 年代后期创建的 xml 变体。
DOMDocument doc = new DOMDocument();
//...load the xml...
IXMLDOMNodeList nodes = doc.selectNodes('/NewDataSet/Table[ValidFromDate>"2013-02-12"]');
但该版本的 MSXML 不是“符合标准”(因为它是在有标准之前创建的)。 Since 2005 the recommended one, the one that follows the standards, the only one that has features I require是 MSXML 6。
这是一个简单的更改,只需实例化一个 DOMDocument60
类而不是 DOMDocument
类:
DOMDocument doc = new DOMDocument60();
//...load the xml...
IXMLDOMNodeList nodes = doc.selectNodes('/NewDataSet/Table[ValidFromDate>"2013-02-12"]');
除了相同的 XPath 查询不返回任何内容。
按日期过滤值的“符合标准”方法是什么?
您可能认为我可能认为 XML 正在处理 2013-02-01T00:00:00-05:00
作为某种特殊日期,而实际上它是一个字符串。所以也许我应该将其视为字符串比较。
这会起作用,但它不起作用。没有字符串比较工作:
/NewDataSet/Table[ValidFromDate<"a"]
不返回任何节点/NewDataSet/Table[ValidFromDate>"a"]
不返回任何节点/NewDataSet/Table[ValidFromDate!="a"]
返回所有节点/NewDataSet/Table[ValidFromDate>"2014-02-12T00:00:00-05:00"]
不返回任何节点/NewDataSet/Table[ValidFromDate<"2014-02-12T00:00:00-05:00"]
不返回任何节点/NewDataSet/Table[ValidFromDate!="2014-02-12T00:00:00-05:00"]
不返回任何节点什么是“符合标准”的方法来实现过去的工作?
XPath 查询日期字符串的“正确”方法是什么?
或者,更好的是,为什么我的 XPath 查询不起作用?
或者,更好的是更好,为什么曾经有效的查询不再有效?决定语法错误的决定是什么。他们通过“破坏”查询语法解决了哪些极端情况?
这是最终的功能代码,几乎是我使用的语言:
DOMDocument60 GetXml(String url)
{
XmlHttpRequest xml = CoServerXMLHTTP60.Create();
xml.Open('GET', url, False, '', '');
xml.Send(EmptyParam);
DOMDocument60 doc = xml.responseXML AS DOMDocument60;
//MSXML6 removed all kinds of features originally present (thanks W3C)
//Need to use Microsoft's proprietary extensions to get some of it back (thanks W3C)
doc.setProperty('SelectionNamespaces', 'xmlns:ms="urn:schemas-microsoft-com:xslt"');
return doc;
}
DOMDocument doc = GetXml('http://example.com/GetBanks.ashx?employeeID=12345');
//Finds future banks.
//Only works in MSXML3; intentionally broken in MSXML6 (thanks W3C):
//String qry = '/NewDataSet/Table[ValidFromDate > "2014-02-12"]';
//MSXML6 compatible version of doing the above (send complaints to W3C);
String qry = '/NewDataSet/Table[ms:string-compare(ValidFromDate, "2014-02-12") >= 0]';
IXMLDOMNodeList nodes = doc.selectNodes(qry);
最佳答案
What is the "correct" way to XPath query for date strings?
在 XPath 1.0 中,无法处理日期字符串,只能考虑时区支持。至少没有正确的方法来处理它们。如果时区不同,比较字符串将失败。
Or, better yet, why are my XPath queries not working?
XPath 1.0 仅在字符串上定义相等运算符,用于大于/小于值 have to be converted to numbers .
使用ms:string-compare
这是在 MSXML 4.0 中引入的。
/NewDataSet/Table[
ms:string-compare(ValidFromDate, "2014-02-12T00:00:00-05:00") > 0
]
What is the "standards compliant" way to achieve what used to work?
一个也适用于其他 XPath 实现的替代方案(我使用 xmllint
测试了它,它使用 libxml
)可能是 翻译
所有非字符串字符,因此字符串将被解析为数字:
/NewDataSet/Table[
translate(ValidFromDate, "-:T", "") < translate("2014-02-12T00:00:00-05:00", "-:T", "")
]
关于xml - 按日期过滤 XPath 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21663262/
正如标题中所问,我有两个如下结构的 XML 文件 A.xml //here I want to include B.xml
我有一个 xml 文件。根据我的要求,我需要更新空标签,例如我需要更改 to .是否可以像那样更改标签.. 谢谢... 最佳答案 var xmlString=" "; var properStri
我有这样简单的 XML: Song Playing 09:41:18 Frederic Delius Violin Son
在我的工作中,我们有自己的 XML 类来构建 DOM,但我不确定应该如何处理连续的空格? 例如 Hello World 当它被读入 DOM 时,文本节点应该包含 Hello 和 World
我有以下 2 个 xml 文件,我必须通过比较 wd:Task_Name_ID 和 TaskID 的 XML 文件 2。 例如,Main XML File-1 wd:Task_Name_ID 具有以下
我在 Rails 应用程序中有一个 XML View ,需要从另一个文件插入 XML 以进行测试。 我想说“构建器,只需盲目地填充这个字符串,因为它已经是 xml”,但我在文档中看不到这样做的任何内容
我正在重建一些 XML 提要,因此我正在研究何时使用元素以及何时使用带有 XML 的属性。 一些网站说“数据在元素中,元数据在属性中。” 那么,两者有什么区别呢? 让我们以 W3Schools 为例:
在同一个文档中有两个 XML 声明是否是格式正确的 XML? hello 我相信不是,但是我找不到支持我的消息来源。 来自 Extensible Markup Language
我需要在包装器 XML 文档中嵌入任意(语法上有效的)XML 文档。嵌入式文档被视为纯文本,在解析包装文档时不需要可解析。 我知道“CDATA trick”,但如果内部 XML 文档本身包含 CDAT
XML 解析器和 XML 处理器是两个不同的东西吗?他们是两个不同的工作吗? 最佳答案 XML 解析器和 XML 处理器是一样的。它不适用于其他语言。 XML 是通用数据标记语言。解析 XML 文件已
我使用这个 perl 代码从一个文件中读取 XML,然后写入另一个文件(我的完整脚本有添加属性的代码): #!usr/bin/perl -w use strict; use XML::DOM; use
我正在编写一个我了解有限的历史脚本。 对象 A 的类型为 system.xml.xmlelement,我需要将其转换为类型 system.xml.xmldocument 以与对象 B 进行比较(类型
我有以下两个 XML 文件: 文件1 101 102 103 501 502 503
我有以下两个 XML 文件: 文件1 101 102 103 501 502 503
我有一个案例,其中一个 xml 作为输入,另一个 xml 作为输出:我可以选择使用 XSL 和通过 JAXB 进行 Unmarshalling 编码。性能方面,有什么真正的区别吗? 最佳答案 首先,程
我有包含 XML 的 XML,我想使用 JAXB 解析它 qwqweqwezxcasdasd eee 解析器 public static NotificationRequest parse(Strin
xml: mario de2f15d014d40b93578d255e6221fd60 Mario F 23 maria maria
尝试更新 xml 文件数组时出现以下错误。 代码片段: File dir = new File("c:\\XML"); File[] files = dir.listFiles(new Filenam
我怎样才能完成这样的事情: PS /home/nicholas/powershell> PS /home/nicholas/powershell> $date=(Get-Date | ConvertT
我在从 xml 文件中删除节点时遇到一些困难。我发现很多其他人通过各种方式在 powershell 中执行此操作的示例,下面的代码似乎与我见过的许多其他示例相同,但我没有得到所需的行为。 我的目标是将
我是一名优秀的程序员,十分优秀!