XML в JSON преобразование с использованием выражения XPath - PullRequest
0 голосов
/ 09 апреля 2020

Мне нужно преобразовать формат XML в JSON, используя выражение XPath. Есть ли способ, которым я могу достичь этого?

Я пытался использовать функцию xml -to- json, но я не понимаю, как я должен предоставить аргументы функции.

Мне нужно только запустить выражение XPath, я не могу использовать XSLT для достижения того же.

XML:

<?xml version="1.0" encoding="UTF-8"?>
<bookstore>
    <book category="cooking">
        <title lang="en">Everyday Italian</title>
        <author>Giada De Laurentiis</author>
        <year>2005</year>
        <price>30.00</price>
        <location>DL</location>
    </book>
    <book category="children">
        <title lang="es">Harry Potter</title>
        <author>J K. Rowling</author>
        <year>2005</year>
        <price>29.99</price>
        <location>UP</location>
    </book>
    <book category="web">
        <title lang="en">XQuery Kick Start</title>
        <author>James McGovern</author>
        <author>Per Bothner</author>
        <author>Kurt Cagle</author>
        <author>James Linn</author>
        <author>Vaidyanathan Nagarajan</author>
        <year>2003</year>
        <price>49.99</price>
        <location>  DL</location>
    </book>
    <book category="web">
        <title lang="en">Learning XML</title>
        <author>Erik T. Ray</author>
        <year>2003</year>
        <price>39.95</price>
        <location>dl </location>
    </book>
    <category>web</category>
</bookstore>

1 Ответ

0 голосов
/ 09 апреля 2020

Это действительно расширяет возможности XPath, даже если у вас версия 3.1. Вы действительно должны использовать XSLT или XQuery.

Тем не менее, я думаю, что это возможно, но без использования функции xml -to- json (). Вам нужно что-то вроде

serialize (
  map { "bookstore": 
    array { //book !
      map { "category" : string(@category),
            "title" : string(title),
            "authors" : 
               array { author ! string(.) },
            "year" : number(year)
          }
    }
  },
  map{"method" : "json"}
)
...