- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这对我来说是个脑筋急转弯:
假设我有类似于以下的 XML 数据:
<?xml version="1.0"?>
<site>
<open_auction id="open_auction0">
<initial>25.39</initial>
<reserve>67.91</reserve>
<bidder>
<date>09/27/1999</date>
<time>18:47:09</time>
<personref person="person308"/>
<increase>18.00</increase>
</bidder>
<bidder>
<date>06/03/2000</date>
<time>17:47:49</time>
<personref person="person942"/>
<increase>19.50</increase>
</bidder>
<bidder>
...
</bidder>
<current>202.39</current>
<itemref item="item2"/>
<seller person="person573"/>
<annotation>
<author person="person128"/>
<description>
<parlist>
<listitem>
<text>
niece <keyword> till banqueting little unkindly </keyword>
</text>
</listitem>
<listitem>
<text>
emilia jack standards
</text>
</listitem>
</parlist>
</description>
<happiness>1</happiness>
</annotation>
<quantity>1</quantity>
<type>Regular</type>
<interval>
<start>12/23/2001</start>
<end>11/11/2000</end>
</interval>
</open_auction>
<open_auction id="open_auction1">
...
</open_auction>
<open_auction id="open_auction2">
...
</open_auction>
</site>
您可以从 www.megamatz.de/auction.xml 下载完整且更大(约 5MB)的测试文件
我需要确定所有 open_auctions 的 ID,其中某个给定的人 (Person1) 在另一个给定的人 (Person2) 之前出价。在一次公开拍卖中,Person1 的“投标人”节点的含义中的“之前”出现在 Person2 的“投标人”节点之前,因此它与日期或时间无关。
这里是这个问题的 XPath-Query 也许它能更好地解释问题:
let $auction := doc("auction.xml") return
for $b in $auction/site/open_auctions/open_auction
where
some $pr1 in $b/bidder/personref[@person = "person20"],
$pr2 in $b/bidder/personref[@person = "person51"]
satisfies $pr1 << $pr2
return <history>{$b/reserve/text()}</history>
我以某种方式知道我需要某种嵌套查询,但我无法直接使用此 Linq 概念和这些 XElement(s)。因此,我不仅对解决方案感兴趣,而且还特别了解 any()、contains() 的概念,以及使用 linq 处理此类查询的其他方法。
我真的很绝望,需要一些帮助,我整晚都在寻找和尝试,但我就是无法弄清楚,但没有任何效果。
编辑添加
很抱歉再次询问,但是不行,它不起作用。我试了又试,非常好,因为我学到了很多东西。我感觉我快要找到答案了,但是当涉及到“ElementAfterSelf”时,我可以在这个复杂查询的上下文中使用一些提示和解释。
这是我的方法,是我根据从 Jon Skeets 的回答中学到的知识得出的:
List<XElement> = doc.Descendants("open_auction")
.Where(x => x.Element("bidder") != null && x.Elements("bidder")
.Any(b => b.Elements("personref")
.First(c => c.IsBidder("person540"))
.ElementsAfterSelf("bidder").Any(d => d.IsBidder("person1068"))
)).ToList();
但它也不起作用。但是……:
List<XElement> j = XMarkXML.Element("site").Element("open_auctions").Elements("open_auction")
.Where(x => x.Element("bidder") != null && x.Elements("bidder")
.Any(b => b.Elements("personref")
.Any(c => c.IsBidder("person540")) //I changed First with Any
//.ElementsAfterSelf().Any(d => d.IsBidder("person1068")) //and commented the last part out
)).ToList();
...至少提出了 3 个“open_auction”,其中“person540”是投标人。具体来说,在我的测试文件中,它是 id="open_auction11",其中“person1068”出价“在”“person540”之后。
我发自内心地问,有人可以用测试文件试一试吗?我将它上传到 www.megamatz.de/auction.xml 。在文件中,公开拍卖的路径是:Element("site").Element("open_auctions").Elements("open_auction")
最佳答案
编辑:好的,再次编辑。我认为这没问题,但即使有您的示例文件,如果您能给我们一个输入和预期输出的具体示例,那就太好了:
// Extension methods
internal static bool IsBidder(this XElement bidder, string person)
{
return (string) bidder.Element("personref")
.Attribute("person") == person;
}
internal static IEnumerable<XElement> ElementsAfterFirst
(this IEnumerable<XElement> source, XName name)
{
var first = source.FirstOrDefault();
if (first != null)
{
foreach (var element in first.ElementsAfterSelf(name))
{
yield return element;
}
}
}
var query = doc
.Descendants("open_auction")
.Where(x => x.Elements("bidder")
// All the person20 bids...
.Where(b => b.IsBidder("person20"))
// Now project to bids after the first one...
.ElementsAfterFirst("bidder")
// Are there any from person51? If so, include this auction.
.Any(b => b.IsBidder("person51"))
);
第二种扩展方法也可以写成:
internal static IEnumerable<XElement> ElementsAfterFirst
(this IEnumerable<XElement> source, XName name)
{
var first = source.FirstOrDefault();
return first == null ? new XElement[0] : first.ElementsAfterSelf(name);
}
它稍微改变了时间,但在这种特殊情况下应该没有任何区别......
关于c# - 处理 Linq XML 和复杂查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7377198/
我之前发布过question已得到答复,但我也需要对此进行查询。我有一个包含这样数据的表结构(日期格式为 dd/mm/yyyy)。 ID Account Number Unit Ad
我正在使用 React Native Calendars 并尝试为议程组件构建我的数据。 预期的数据结构是(一个对象) { '2012-05-22': [{text: 'item 1 - any j
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
两列城镇和优先级。 我需要对表进行排序,以便优先级=1的城镇排在第一位,并且不按名称 ASC 排序,而其余城镇则按名称 ASC 排序。 我该怎么做? 谢谢;) 更新 SELECT * FROM map
我有三个表“Hardware_model”、“Warehouse”和“Brand”,并且表以这种方式一起引用:Hardware_model 仓库Hardware_model 品牌 现在我要执行以下
我有一个 MySQL 表 (tbl_filters),包含 3 列:id、cat、val id 和 val 是数字,cat 是 varchar。每个 id 有多行。 我还有另一个包含多个列的表 (tb
我想获取字段的不同值,比方说:field1...这需要一个如下查询:“从表中选择不同的(字段1)” 但是,对于某些记录,field1 为空,并且还有另一列可以替代 field1,即 field2。对于
表 1 - 用户 id username items 1 Paul 1(0020);2(0001); 表 2 - 项目 id name 1 name_here 在我的用户的项目中,我输入了 2(000
我想连接同一个表 4 次以获取列的显示方式,我不确定是否可以在 1 个 SQL 语句中完成。 tbl_用户名 id username 1 Adam 2 Bob 3 Chris tbl_机
首先,我刚刚开始自己学习JS,没有任何编程经验,这意味着我仍然要了解这种出色的编程语言的基本构建模块。 我的问题与我编写的以下代码有关: let orderCount = 0; con
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 9 年前。 Improve t
我正在使用 XMAPP,MySQL 正在正常运行。在 phpMyAdmin 中,我不太明白这一点,所以我尝试在 PHP 中创建一个。使用此代码,它会告诉我数据库 benutzer。尽管我在 phpMy
是否有一种高效的算法可以找到平均度最大的子图(可能是图本身)? 最佳答案 The paper "Finding a Maximum-Density Subgraph" by Andrew Goldbe
目录 1、业务背景 2、场景分析 3、流程设计 1、业务流程 2、导入流程
我有 2 个表: 1) 包含自 1900 年 1 月 1 日以来所有日期的 Masterdates 表 2) Stockdata 表,其中包含表单中的股票数据 日期、交易品种、开盘价、最高价、最低价、
我有一个非常复杂的 UI,其状态栏不断变化,其中包含多种类型的状态消息,并且 UI 具有复杂的图表控件和已加载的指示性地理 map 。 现在这些小而复杂的区域的数据上下文具有同样复杂的 ViewMod
有人可以用简单的方式向我解释为什么常量在大 O 表示法中无关紧要吗?为什么添加常量时复杂性保持不变。这不是作业问题,我只是想更好地理解这一点。让我明白这个大 O 是为了看到一个函数在接近无穷大时的行为
我在 flex 搜索索引中有以下文档。 [{ "_index": "ten2", "_type": "documents", "_id": "c323c
我有一个以零碎的方式构建的 LINQ 查询,如下所示: var initialQuery = from item in MyContext where xxx == yyy select item;
我目前正在涉足 SQL,并且希望针对我所创建的问题获得一些帮助。 为了练习一些编程,我正在制作一个 IOU 应用程序。下面是我存储的表我的借条记录(忽略一些相关栏目)。该表允许用户说“嘿,你欠我 X
我是一名优秀的程序员,十分优秀!