Compare commits
1 Commits
3b96031a42
...
xalan_sing
| Author | SHA1 | Date | |
|---|---|---|---|
| 04220e3c98 |
@@ -1,5 +1,3 @@
|
|||||||
from typing import Any
|
|
||||||
|
|
||||||
from lxml import etree, html
|
from lxml import etree, html
|
||||||
from io import BytesIO
|
from io import BytesIO
|
||||||
|
|
||||||
@@ -81,11 +79,9 @@ def xpath(source: str, xpath: str) -> str:
|
|||||||
else:
|
else:
|
||||||
result_string = ""
|
result_string = ""
|
||||||
for e in result:
|
for e in result:
|
||||||
if isinstance(e, etree._Element):
|
result_string += etree.tostring(e, pretty_print=True).decode() + "\n"
|
||||||
result_string += etree.tostring(e, pretty_print=True).decode() + "\n"
|
return result_string, "node"
|
||||||
else:
|
|
||||||
result_string += str(e) + "\n"
|
|
||||||
return result_string, "node"
|
|
||||||
|
|
||||||
|
|
||||||
def xsd(source: str, xsd: str) -> bool:
|
def xsd(source: str, xsd: str) -> bool:
|
||||||
|
|||||||
@@ -18,10 +18,6 @@ import javax.xml.transform.stream.StreamSource;
|
|||||||
import javax.xml.validation.Schema;
|
import javax.xml.validation.Schema;
|
||||||
import javax.xml.validation.SchemaFactory;
|
import javax.xml.validation.SchemaFactory;
|
||||||
import javax.xml.validation.Validator;
|
import javax.xml.validation.Validator;
|
||||||
import javax.xml.xpath.XPath;
|
|
||||||
import javax.xml.xpath.XPathConstants;
|
|
||||||
import javax.xml.xpath.XPathExpression;
|
|
||||||
import javax.xml.xpath.XPathFactory;
|
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.OutputStreamWriter;
|
import java.io.OutputStreamWriter;
|
||||||
import java.io.StringReader;
|
import java.io.StringReader;
|
||||||
@@ -65,13 +61,6 @@ public class Xalan implements XmlEngine{
|
|||||||
return nodeType == Node.CDATA_SECTION_NODE || nodeType == Node.TEXT_NODE;
|
return nodeType == Node.CDATA_SECTION_NODE || nodeType == Node.TEXT_NODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isAttributeNode(Node n) {
|
|
||||||
if (n == null)
|
|
||||||
return false;
|
|
||||||
short nodeType = n.getNodeType();
|
|
||||||
return nodeType == Node.CDATA_SECTION_NODE || nodeType == Node.ATTRIBUTE_NODE;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String processXSLT(XMLMultipleFilesData[] data, String transform) throws Exception {
|
public String processXSLT(XMLMultipleFilesData[] data, String transform) throws Exception {
|
||||||
throw new UnsupportedOperationException("Xalan does not support multiple files XSLT processing");
|
throw new UnsupportedOperationException("Xalan does not support multiple files XSLT processing");
|
||||||
@@ -112,10 +101,7 @@ public class Xalan implements XmlEngine{
|
|||||||
for (Node nn = n.getNextSibling(); isTextNode(nn); nn = nn.getNextSibling()) {
|
for (Node nn = n.getNextSibling(); isTextNode(nn); nn = nn.getNextSibling()) {
|
||||||
resultString.append(nn.getNodeValue());
|
resultString.append(nn.getNodeValue());
|
||||||
}
|
}
|
||||||
} else if (isAttributeNode(n)) {
|
} else {
|
||||||
resultString.append(n.getNodeValue());
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
|
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
|
||||||
serializer.transform(new DOMSource(n), new StreamResult(new OutputStreamWriter(outputStream)));
|
serializer.transform(new DOMSource(n), new StreamResult(new OutputStreamWriter(outputStream)));
|
||||||
resultString.append(outputStream);
|
resultString.append(outputStream);
|
||||||
|
|||||||
Reference in New Issue
Block a user