Как сохранить MSXML2.DomDocument с отступом? (Я думаю, что он использует MXXMLWriter)
У меня есть экземпляр MSXML2.DomDocument.
Я Машу, чтобы сохранить его, с отступом.
этот код работает, но не отступ:
var dom = new ActiveXObject("MSXML2.DomDocument");
// fiddle with dom here
dom.save(filename);
Я думаю, что могу использовать объект MXXMLWriter для вставки отступа.
Как?
3 ответов
Это должно сделать это.
function saveDomWithIndent(dom, filename) {
var writer = new ActiveXObject("MSXML2.MXXMLWriter"),
reader = new ActiveXObject("MSXML2.SAXXMLReader"),
fso = new ActiveXObject("Scripting.FileSystemObject"),
textStream = fso.CreateTextFile(filename, true);
writer.indent = true;
writer.omitXMLDeclaration = true;
reader.contentHandler = writer;
reader.parse(dom);
textStream.Write(writer.output);
textStream.Close();
}
используйте его так:
var root, node, newnode,
dom = new ActiveXObject("MSXML2.DOMDocument.6.0");
dom.async = false;
dom.resolveExternals = false;
dom.load(fullpath);
root = dom.documentElement;
node = root.selectSingleNode("/root/node1");
if (node !== null) {
newnode = dom.createElement('node2');
newnode.text = "hello";
root.appendChild(newnode);
saveDomWithIndent(dom, fullpath);
}
Я не мог понять, как отрегулировать уровень отступа. Он всегда отступает с tab.
есть еще один способ для prettifying xml выходов, плюс вы можете настроить уровень отступа вручную:xsl-код.
var adSaveCreateOverWrite = 2
var Indent = new ActiveXObject("MSXML2.DomDocument");
Indent.async = false;
Indent.resolveExternals = false;
Indent.load("indent.xsl");
var Doc = new ActiveXObject("MSXML2.DomDocument");
Doc.async = false;
Doc.resolveExternals = false;
Doc.load("dirty.xml");
with(new ActiveXObject("ADODB.Stream")){
Charset = "utf-8";
Open();
WriteText(Doc.transformNode(Indent));
SaveToFile("pretty.xml", adSaveCreateOverWrite);
Close();
}
отступ.язык xsl
<?xml version="1.0" encoding="ISO-8859-15"?>
<!-- http://x443.wordpress.com/2011/page/34/ -->
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml"/>
<xsl:template match="@*">
<xsl:copy/>
</xsl:template>
<xsl:template match="text()">
<xsl:value-of select="normalize-space(.)" />
</xsl:template>
<xsl:template match="*">
<xsl:param name="indent" select="''"/>
<xsl:text>
</xsl:text>
<xsl:value-of select="$indent" />
<xsl:copy>
<xsl:apply-templates select="@*|*|text()">
<xsl:with-param name="indent" select="concat($indent, ' ')"/>
</xsl:apply-templates>
</xsl:copy>
<xsl:if test="count(../*)>0 and ../*[last()]=.">
<xsl:text>
</xsl:text>
<xsl:value-of select="substring($indent,3)" />
</xsl:if>
</xsl:template>
</xsl:stylesheet>
Если вы не хотите использовать xsl, вы можете просто вставить vbcrlfs. Каждые ">" следует vbcrlf, кроме случаев, когда ">" следует число. Затем создайте новый xml-файл из этой строки - Теперь у него есть новые строки и отступы. msaccess vba:
Dim objDom As DOMDocument
Set objDom = CreateObject("MSXML2.DOMDocument")
создать документ с objDom.добавьте, затем поиграйте со строкой (мой xml имел только цифры):
ss = objectDom.XML
For i = 1 To Len(ss)
c = Mid(ss, i, 1)
If InStr(1, Mid(ss, i, 1), ">") > 0 Then
a = Asc(Mid(ss, i + 1, 1))
If a < 48 Or a > 57 Then
ss1 = Mid(ss, 1, i)
ss2 = Mid(ss, i + 1, Len(ss))
ss = Mid(ss, 1, i) & vbCrLf & Mid(ss, i + 1, Len(ss))
End If
End If
Next i
objDom.loadXML ss
objDom.Save (file_path)