Я пытаюсь объединить два xml-файла и с XSLT-файлом преобразовать их в XHTML-страницу. Я не делал этого раньше и не могу понять, как это сделать. Это то, что я до сих пор, с одним XML-файлом:
<?php $xsl = new DOMDocument(); $xsl->load("file.xsl"); $inputdom = new DomDocument(); $inputdom->load("file.xml"); $proc = new XSLTProcessor(); $xsl = $proc->importStylesheet($xsl); $proc->setParameter(null, "", ""); $newdom = $proc->transformToDoc($inputdom); print $newdom-> saveXML();
xsl-файл с пространством имен ss. Я не уверен, как использовать префикс ss?
<?xml version="1.0" encoding="utf-8"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet"> <xsl:template match="/"> <html> <body> <table border="1"> <tr bgcolor="#9acd32"> <th>Title</th> <th>Title2</th> </tr> <xsl:for-each select="something/some"> <tr> <td><xsl:value-of select="title"/></td> <td><xsl:value-of select="title2"/></td> </tr> </xsl:for-each> </table> </body> </html> </xsl:template>
2<?xml version="1.0" encoding="utf-8"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet"> <xsl:template match="/"> <html> <body> <table border="1"> <tr bgcolor="#9acd32"> <th>Title</th> <th>Title2</th> </tr> <xsl:for-each select="something/some"> <tr> <td><xsl:value-of select="title"/></td> <td><xsl:value-of select="title2"/></td> </tr> </xsl:for-each> </table> </body> </html> </xsl:template>
XML-файл
<?xml version="1.0" encoding="iso-8859-1"?> <?xml-stylesheet type="text/xsl" href="file.xsl"?> <something> <some> <Firstname>Peter</Firstname> <Lastname>Anderson</Lastname> <some> .....
-<?xml version="1.0" encoding="iso-8859-1"?> <?xml-stylesheet type="text/xsl" href="file.xsl"?> <something> <some> <Firstname>Peter</Firstname> <Lastname>Anderson</Lastname> <some> .....
Если бы кто-то мог дать мне удар в правильном направлении, я был бы благодарен.
Вот второй xml-файл:
<?xml version="1.0"?> <Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet" xmlns:html="http://www.w3.org/TR/REC-html40"> <DocumentProperties xmlns="urn:schemas-microsoft-com:office:office"> <Created>2012-09-25T13:44:01Z</Created> </DocumentProperties> <OfficeDocumentSettings xmlns="urn:schemas-microsoft-com:office:office"> <AllowPNG/> </OfficeDocumentSettings> <ExcelWorkbook xmlns="urn:schemas-microsoft-com:office:excel"> <WindowHeight>14060</WindowHeight> <WindowWidth>25040</WindowWidth> <WindowTopX>25540</WindowTopX> <WindowTopY>4100</WindowTopY> <Date1904/> <ProtectStructure>False</ProtectStructure> <ProtectWindows>False</ProtectWindows> </ExcelWorkbook> <Styles> <Style ss:ID="Default" ss:Name="Normal"> <Alignment ss:Vertical="Bottom"/> <Borders/> <Font ss:FontName="Calibri" x:Family="Swiss" ss:Size="12" ss:Color="#000000"/> <Interior/> <NumberFormat/> <Protection/> </Style> <Style ss:ID="s62"> <Font ss:FontName="Courier" ss:Color="#000000"/> </Style> </Styles> <Worksheet ss:Name="Workbook1.csv"> <Table ss:ExpandedColumnCount="5" ss:ExpandedRowCount="79" x:FullColumns="1" x:FullRows="1" ss:DefaultColumnWidth="65" ss:DefaultRowHeight="15"> <Column ss:Index="2" ss:AutoFitWidth="0" ss:Width="43"/> <Column ss:AutoFitWidth="0" ss:Width="113"/> <Column ss:Index="5" ss:AutoFitWidth="0" ss:Width="220"/> <Row ss:Index="6"> <Cell ss:Index="3" ss:StyleID="s62"/> </Row> <Row> <Cell ss:Index="3" ss:StyleID="s62"/> </Row> <Row> <Cell ss:Index="3" ss:StyleID="s62"/> </Row> <Row> <Cell ss:Index="2"><Data ss:Type="String">id</Data></Cell> <Cell ss:StyleID="s62"><Data ss:Type="String">latitude</Data></Cell> <Cell><Data ss:Type="String">longitude</Data></Cell> </Row> <Row> <Cell ss:Index="2"><Data ss:Type="Number">8</Data></Cell> <Cell ss:StyleID="s62"><Data ss:Type="Number">57.4999</Data></Cell> <Cell><Data ss:Type="Number">15.8280</Data></Cell> </Row> .....
электронная<?xml version="1.0"?> <Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet" xmlns:html="http://www.w3.org/TR/REC-html40"> <DocumentProperties xmlns="urn:schemas-microsoft-com:office:office"> <Created>2012-09-25T13:44:01Z</Created> </DocumentProperties> <OfficeDocumentSettings xmlns="urn:schemas-microsoft-com:office:office"> <AllowPNG/> </OfficeDocumentSettings> <ExcelWorkbook xmlns="urn:schemas-microsoft-com:office:excel"> <WindowHeight>14060</WindowHeight> <WindowWidth>25040</WindowWidth> <WindowTopX>25540</WindowTopX> <WindowTopY>4100</WindowTopY> <Date1904/> <ProtectStructure>False</ProtectStructure> <ProtectWindows>False</ProtectWindows> </ExcelWorkbook> <Styles> <Style ss:ID="Default" ss:Name="Normal"> <Alignment ss:Vertical="Bottom"/> <Borders/> <Font ss:FontName="Calibri" x:Family="Swiss" ss:Size="12" ss:Color="#000000"/> <Interior/> <NumberFormat/> <Protection/> </Style> <Style ss:ID="s62"> <Font ss:FontName="Courier" ss:Color="#000000"/> </Style> </Styles> <Worksheet ss:Name="Workbook1.csv"> <Table ss:ExpandedColumnCount="5" ss:ExpandedRowCount="79" x:FullColumns="1" x:FullRows="1" ss:DefaultColumnWidth="65" ss:DefaultRowHeight="15"> <Column ss:Index="2" ss:AutoFitWidth="0" ss:Width="43"/> <Column ss:AutoFitWidth="0" ss:Width="113"/> <Column ss:Index="5" ss:AutoFitWidth="0" ss:Width="220"/> <Row ss:Index="6"> <Cell ss:Index="3" ss:StyleID="s62"/> </Row> <Row> <Cell ss:Index="3" ss:StyleID="s62"/> </Row> <Row> <Cell ss:Index="3" ss:StyleID="s62"/> </Row> <Row> <Cell ss:Index="2"><Data ss:Type="String">id</Data></Cell> <Cell ss:StyleID="s62"><Data ss:Type="String">latitude</Data></Cell> <Cell><Data ss:Type="String">longitude</Data></Cell> </Row> <Row> <Cell ss:Index="2"><Data ss:Type="Number">8</Data></Cell> <Cell ss:StyleID="s62"><Data ss:Type="Number">57.4999</Data></Cell> <Cell><Data ss:Type="Number">15.8280</Data></Cell> </Row> .....
Итак, мой вопрос заключается в том, как объединить данные из обоих XML-файлов с XSLT? Я хочу, чтобы результатом были данные в таблице на странице XHTML.
Это может быть ответом на часть вашего вопроса.
Что касается использования двух файлов XML, у вас есть несколько вариантов. Вы могли бы объединить два файла XML в один более крупный, а затем применить к нему преобразование. Кроме того, вы можете использовать функцию XSLT document()
для загрузки одного из файлов XML из XSLT.
1. Сделайте один большой XML-документ
<?php // XML $x1 = file_get_contents("file1.xml"); $x2 = file_get_contents("file2.xml"); $xml_doc = new DOMDocument(); $xml_doc->loadXML("<root><x1>$x1</x1><x2>$x2</x2></root>"); // XSL $xsl_doc = new DOMDocument(); $xsl_doc->load("file.xsl"); // Proc $proc = new XSLTProcessor(); $proc->importStylesheet($xsl_doc); $newdom = $proc->transformToDoc($xml_doc); print $newdom->saveXML(); ?>
2. Используйте функцию XSTL document()
<?php // XML $xml_doc = new DOMDocument(); $xml_doc->load("file1.xml"); // XSL $xsl_doc = new DOMDocument(); $xsl_doc->load("file.xsl"); // Proc $proc = new XSLTProcessor(); $proc->importStylesheet($xsl_doc); $newdom = $proc->transformToDoc($xml_doc); print $newdom->saveXML(); ?> <?xml version="1.0" encoding="utf-8"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:variable name="file2" select="document('file2.xml')/*"/> <xsl:template match="/"> <xsl:copy-of select="$file2"/> </xsl:template> </xsl:transform>
Я использую первый метод больше, чем второй. Мне не нравятся имена файлов hardcoding в шаблонах XSLT. Когда я использую второй метод, я обычно передавал бы имя файла в качестве внешнего параметра, чтобы избежать его жесткого кодирования в XSLT.