2

轻松FLWOR获取所有数据(来自电子表格

for $foo  in db:open("foo")
return $foo//text()

给出这种类型的输出:

...    
Smallville, XX 12345-1234
Bob 
(123) 456-7809
(123) 876-3468
Smallville, XX 12345-1234
Alice
Smallville, XX 12345-1234
Fred
(123) 654-5432
Smallville, XX 12345-1234
...

另一个返回非数字数据:

for $foo  in db:open("foo")
return $foo//text()[not(matches(., '[0-9]'))]

似乎只返回名称。在这种假设下,希望在 a 上触发关闭标签<person>并打开一个新标签<person>,例如:

<person>
<name>a</name>
<data>123</data>
<data>345</data>
<data>123 main st</data>
</person>

<person>
...
</person>

或类似的东西。只是在假设他们的名字中没有数字的情况下真正想将个人分开,然后在XML.

只要每次找到触发关闭标签然后“开始”一个新人的“名称”。完全不确定这里的标准术语。

4

1 回答 1

3

下面创建一个临时 XML 结构,然后遍历每个name元素,创建一个personwith thename和 it'sfollowing-sibling::data元素。

let $temp := 
  <doc>{
    for $foo in db:open("foo")
    return
      if (matches($foo, "[0-9]")) 
      then <data>{$foo}</data>
      else <name>{$foo}</name>
  }</doc>

for $name in $temp/name
return
  <person>{
    $name,
    $name/following-sibling::data[preceding-sibling::name[1]= $name]
  }</person>
于 2020-02-14T15:34:10.720 回答