У меня есть XML-структура, подобная приведенной ниже (образец XML). Я хочу изменить значение тегов img и изменить их на относительный путь. Каждый XML-документ может содержать более 100 тегов img. Мой код работает по большей части, за исключением того факта, что отклонения пространства имен, которые у меня есть в корневом узле, добавляются к отдельным узлам, ссылающимся на пространство имен, и я не хочу, чтобы это произошло.
Пример XML:
<?xml version="1.0" encoding="UTF-8"?>
<test:document transformVersion="0.0.25" xmlns:test="test.data" xmlns:csp="test.csp" xmlns:cfg="test.cfg">
<data>
<table>
<tr>
<td>
<p class="DataboxTitle">Test Image</p>
</td>
<td>
<p>
<img src="https://www.google.com/images/document/1234.jpg" data-stl="height:107px;width:223px;" srcset="https://www.google.com/images/document/1234.jpg 320w" data-image-title="Test Image"/>
</p>
</td>
</tr>
</table>
<table>
<tr>
<td>
<p class="DataboxTitle">Test Image</p>
</td>
<td>
<p>
<img src="https://www.google.com/images/document/1234.jpg" data-stl="height:107px;width:223px;" srcset="https://www.google.com/images/document/1234.jpg 320w" data-image-title="Test Image"/>
</p>
</td>
</tr>
</table>
<table>
<tr>
<td>
<p class="DataboxTitle">Test Image</p>
</td>
<td>
<p>
<img src="https://www.google.com/images/document/1234.jpg" data-stl="height:107px;width:223px;" srcset="https://www.google.com/images/document/1234.jpg 320w" data-image-title="Test Image"/>
</p>
</td>
</tr>
</table>
<p>
<img src="https://www.google.com/images/document/1234.jpg" data-stl="height:107px;width:223px;" srcset="https://www.google.com/images/document/1234.jpg 320w" data-image-title="Test Image"/>
</p>
</data>
<test:volumes>
<test:test>test</test:test>
</test:volumes>
<csp:volumes>tested</csp:volumes>
</test:document>
В моем коде SwitchCase, приведенном ниже, я знаю, что пространства имен добавляются индивидуально из-за кода '/ *' в объявлении переменной $ doc, но без этого мне понадобится каждый цикл, который испортит другую логику. Я просто хочу, чтобы значения атрибутов тегов img менялись без каких-либо изменений в выходном xml, пожалуйста, предложите выход.
КОД ЗАПРОСА:
xquery version "1.0-ml";
declare variable $doc := fn:doc("/c/temp/test.xml")/*;
declare variable $docId := '1928862612025434112';
declare function local:createTag($docId,$imagePath)
{
let $srcOld := fn:data($imagePath/@src)
let $imageName := fn:tokenize($srcOld,"/")[fn:last()]
return fn:concat("/",$docId,"/media/",$imageName)
};
declare function local:createSrcSetTag($docId,$imagePath)
{
let $srcSetsOld := fn:data($imagePath/@srcset)
for $srcSet in fn:tokenize($srcSetsOld, ",")
let $imageLength := fn:tokenize($srcSet," ")[fn:last()]
let $imageName := fn:tokenize($srcSet,"/")[fn:last()]
let $imageNewPath := fn:concat("/",$docId,"/media/",$imageName)
return fn:concat($imageNewPath,"," )
};
declare function local:change($node as node()*) as node()*
{
typeswitch($node)
case element(img) return
element { xs:QName(fn:local-name($node)) }
{
let $image := $node
let $path := xdmp:path($image)
let $data-stl := fn:data($image/@data-stl)
let $data-image-title := fn:data($image/@data-image-title)
let $srcOld := fn:data($image/@src)
let $srcSetsOld := fn:data($image/@srcset)
let $srcNew := local:createTag($docId,$image)
let $srcSetsNew := local:createSrcSetTag($docId,$image)
return (attribute {'src'}{$srcNew}, attribute {'data-stl'}{$data-stl},attribute {'srcset'}{$srcSetsNew}, attribute {'data-image-title'}{$data-image-title} )
}
case element() return
element {fn:node-name($node) } {
$node/@*,
$node/node() ! local:change(.)
}
default return $node
};
local:change(($doc))
Это мой вывод после преобразования:
<test:document transformVersion="0.0.25" xmlns:test="test.data">
<data>
<table>
<tr>
<td>
<p class="DataboxTitle">Test Image</p>
</td>
<td>
<p>
<img src="/1928862612025434112/media/1234.jpg" data-stl="height:107px;width:223px;" srcset="/1928862612025434112/media/1234.jpg 320w," data-image-title="Test Image"/>
</p>
</td>
</tr>
</table>
<table>
<tr>
<td>
<p class="DataboxTitle">Test Image</p>
</td>
<td>
<p>
<img src="/1928862612025434112/media/1234.jpg" data-stl="height:107px;width:223px;" srcset="/1928862612025434112/media/1234.jpg 320w," data-image-title="Test Image"/>
</p>
</td>
</tr>
</table>
<table>
<tr>
<td>
<p class="DataboxTitle">Test Image</p>
</td>
<td>
<p>
<img src="/1928862612025434112/media/1234.jpg" data-stl="height:107px;width:223px;" srcset="/1928862612025434112/media/1234.jpg 320w," data-image-title="Test Image"/>
</p>
</td>
</tr>
</table>
<p>
<img src="/1928862612025434112/media/1234.jpg" data-stl="height:107px;width:223px;" srcset="/1928862612025434112/media/1234.jpg 320w," data-image-title="Test Image"/>
</p>
</data>
<test:volumes>
<test:test>test</test:test>
</test:volumes>
<csp:volumes xmlns:csp="test.csp">tested</csp:volumes>