- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试使用 DocumentBuilder 在 Java 中编写一个简单的 XML 文件。我希望 XML 文件看起来像这样:
<outer>
<inner>
<element name="WEB"/>
<element name="WEB"/>
<element name="WEB"/>
</inner>
</outer>
但是它是这样生成的:
<outer>
<inner>
<element name="WEB"/>
<element name="WEB"/>
<element name="WEB"/>
</inner>
</outer>
为什么第三个元素与其他两个元素的缩进不同?注意:我再次读取XML文件模拟了一个项目中的方法,读取一个XML文件,添加一个元素并保存到XML文件中。这是我的代码:
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.xml.sax.SAXException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.*;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import java.io.File;
import java.io.IOException;
public class main {
private static String FILEPATH = "/tmp/xmltest.xml";
private static DocumentBuilderFactory docFactory;
private static DocumentBuilder docBuilder;
private static TransformerFactory transformerFactory;
private static Transformer transformer;
public static void main(String[] args) throws IOException, SAXException, ParserConfigurationException, TransformerConfigurationException, TransformerException{
docFactory = DocumentBuilderFactory.newInstance();
docBuilder = docFactory.newDocumentBuilder();
transformerFactory= TransformerFactory.newInstance();
transformer = transformerFactory.newTransformer();
transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
transformer.setOutputProperty(OutputKeys.INDENT, "yes");
transformer.setOutputProperty("{http://xml.apache.org/xslt}indent-amount", "1");
// Creating the XML file structure
Document document = docBuilder.newDocument();
Element rootElement = document.createElement("outer");
document.appendChild(rootElement);
Element inner = document.createElement("inner");
rootElement.appendChild(inner);
// Write XML file
write(document);
// Read XML file
document = docBuilder.parse(FILEPATH);
Element root = document.getDocumentElement();
Element innerElement = (Element)root.getElementsByTagName("inner").item(0);
// Add element
Element e = document.createElement("element");
e.setAttribute("name", "WEB");
innerElement.appendChild(e);
// Add element
e = document.createElement("element");
e.setAttribute("name", "WEB");
innerElement.appendChild(e);
// Write XML file
write(document);
// Read XML fil
document = docBuilder.parse(FILEPATH);
root = document.getDocumentElement();
innerElement = (Element)root.getElementsByTagName("inner").item(0);
// Add element
e = document.createElement("element");
e.setAttribute("name", "WEB");
innerElement.appendChild(e);
// Write XML file
write(document);
}
private static void write(Document document) throws TransformerException {
DOMSource source = new DOMSource(document);
StreamResult result = new StreamResult(new File(FILEPATH));
transformer.transform(source, result);
}
}
最佳答案
xmlfile 中用于缩进的文本节点被视为数据。因此,您的缩进将被折腾。您可以按如下方式解决此问题:
private static void removeEmptyText(Node node){
Node child = node.getFirstChild();
while(child!=null){
Node sibling = child.getNextSibling();
if(child.getNodeType()==Node.TEXT_NODE){
if(child.getTextContent().trim().isEmpty())
node.removeChild(child);
}else
removeEmptyText(child);
child = sibling;
}
}
private static void write(Document document) throws TransformerException {
removeEmptyText(document.getDocumentElement());
DOMSource source = new DOMSource(document);
StreamResult result = new StreamResult(new File(FILEPATH));
transformer.transform(source, result);
}
这里我在写入文件之前从 dom 中删除所有缩进文本节点。
关于Java DocumentBuilder - XML 文件中的错误缩进,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31413413/
我有一个带有 JFileChooser 的基本 Java-UI。 我尝试使用以下代码解析所选文件: Document document = builder.parse(getClass().getRe
我试图向文档生成器解析一个包含井号标签 (#) 的 xml 路径,但它不起作用,似乎解析器会忽略 # 后面的所有内容。有谁知道我能做什么吗? 这是代码: Document document = Doc
我正在查看的当前代码库使用 DOM 解析器。以下代码片段在 5 种方法中重复: DocumentBuilderFactory factory = DocumentBuilderFactory.new
我有一个包含页眉/页脚的模板文档,我必须插入多个文档。在每个文档之后我需要插入一个分页符。 在com.aspose.words.DocumentBuilder中有一个insertDocument()和
这个问题已经有答案了: How to fix error: The markup in the document following the root element must be well-for
我正在尝试从给定的 URL 解析一些 XML。代码如下: try { URL myUrl = new URL(sURL); URLCon
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance (); DocumentBuilder dBuilder =
我在 JAVA 中使用 DocumentBuilder Factory 来创建 XML 文件,并且在我的 createTextNode() 方法中“null”值 Not Acceptable 。 El
在此 Document document = documentBuilder.parse(filename); 我正在尝试通过缓冲输入流读取一组Xml文件。当我在命令提示符中输入文件时,出现错误 As
我是解析 XML 的新手,并且遇到实体问题。 (我正在 Android 上执行此操作,如果有影响的话)。 有没有办法让它把一个实体变成它所代表的角色?我在元素的子元素中有这个:“isn't”(减去引号
我正在尝试使用以下代码在 java 中解析 xml File fXmlFile = new File(DAL_DB_ALARM_MOVED_XML); DocumentBuilderFactory d
我尝试使用 DocumentBuilder 在 Java 中编写一个简单的 XML 文件。我希望 XML 文件看起来像这样:
我正在尝试合并 4 个 word 文档并强制每个文档的内容从新页面开始。但是,它不是将每个文档的文本附加到单独的页面,而是将所有文档的文本添加到一个页面。像这样: 我该如何解决?这是代码: publ
我目前正在从 PHP 脚本(如下所示)读取 XML 文件,该文件工作正常,但是我现在想添加某种形式的 HTTP 超时来检索 XML。 DocumentBuilderFactory docBuilder
我正在尝试根据 XSD 架构验证某些 XML 输入。解析器可以工作,但是当我 Hook 模式时,出现以下异常。我已经使用外部 validator 验证了测试输入,所以我已经消除了它。有谁知道如何设置一
我正在尝试将包含 XML 文档的树(扩展 JTree)保存到已更改其结构的 DOM 对象。 我已经创建了一个新的文档对象,遍历树并成功检索了内容(包括 XML 文档的原始编码),现在有一个 ByteA
是标准的Java 1.6 javax.xml.parsers.DocumentBuilder类线程安全吗?从多个线程并行调用 parse() 方法是否安全? JavaDoc 没有提到这个问题,但 Ja
谁能告诉我应该在什么情况下将 setNamespaceAware 设置为 true 或 false 根据文档指定由此代码生成的解析器将提供对 XML 命名空间的支持。 但是,如果我将其设置为 true
我的 Java 经验很少。我试图强制将文档读取为 UTF-8,但在尝试将 InputStream 阅读器连接到文档生成器时遇到了困难。 这是我到目前为止所拥有的: import javax.xml.x
我正在尝试使用采用 InputSource 的 parse 方法来解析 DocumentBuilder 实例。 错误是: The method parse(InputStream) in the ty
我是一名优秀的程序员,十分优秀!