0

我有以下 XML,从 Web 服务返回(猜测电影加分 5 分):

<ArrayOfSub xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="http://tempuri.org/">
  <Sub>
    <SubId>862</SubId>
    <SubStreamId>1</SubStreamId>
    <SubTimeStart>00:01:04.4450000</SubTimeStart>
    <SubTimeEnd>00:01:08.2450000</SubTimeEnd>
    <SubText>Wikus van de Merwe
MNU Alien Affairs

    </SubText>
  </Sub>
  <Sub>
    <SubId>863</SubId>
    <SubStreamId>1</SubStreamId>
    <SubTimeStart>00:02:11.3430000</SubTimeStart>
    <SubTimeEnd>00:02:14.8430000</SubTimeEnd>
    <SubText>Sarah Livingstone
Sociologist, Kempton Park University

    </SubText>
  </Sub>
</ArrayOfSub>

我需要<SubText>满足以下条件的所有元素的元素:

SubTimeStart < now && SubTimeEnd > now

我在 Javascript 中为 Palm Pre 上的 WebOs 应用程序执行此操作。我不确定哪种分辨率适合我的prototype.js PeriodicExecuter,但1/100 秒似乎工作正常。

什么 XPath 查询将返回代表现在应该在屏幕上的元素?

4

3 回答 3

1

试试这个:


var district = 9; // hint

var now = "00:00:00.123"; // manual format is an option?
var xpath = "/ArrayOfSub/Sub["+
    " SubTimeStart <= " + now + " and " +
    " SubTimeEnd   >= " + now + "]/SubText"
 
于 2009-10-05T00:52:06.577 回答
0

XPath 确实有一些日期处理功能——尽管该列表中似乎没有提到毫秒。

我想查询会是这样的:

nowH = 0;
nowM = 2;
nowS = 26;

/ArrayOfSub/sub     //linebreaks added for readability
    [fn:hours-from-time(SubTimeStart) <= nowH]
    [fn:minutes-from-time(SubTimeStart) <= nowM]
    [fn:seconds-from-time(SubTimeStart) <= nowS]
    [fn:hours-from-time(SubTimeEnd) >= nowH]
    [fn:minutes-from-time(SubTimeEnd) >= nowM]
    [fn:seconds-from-time(SubTimeEnd) >= nowS]
    /SubText
于 2009-10-05T00:30:05.253 回答
0

XPath2 支持日期和时间,所以如果 WebOs 使用 XPath2,你可以做一些简单的事情,比如:

//Sub[(SubStartTime < '00:02:13.243') and SubEndTime > '00:02:13.243']

否则,您可以将时间转换为简单的整数,如下所示:

//Sub[
  (concat(substring(SubTimeStart,1,2), substring(SubTimeStart,4,2), substring(SubTimeStart,7)) < '000213.243')
and
  (concat(substring(SubTimeEnd,1,2), substring(SubTimeEnd,4,2), substring(SubTimeEnd,7)) > '000213.243')
]

这些查询应选择第二项。

于 2009-10-05T00:54:21.740 回答