Mi chiedevo se sarebbe stato facile farlo con la libreria XOM e provarlo.
si è rivelato essere abbastanza facile:
import nu.xom.*;
import java.io.File;
import java.io.IOException;
public class RemoveEmptyTags {
public static void main(String[] args) throws IOException, ParsingException {
Document document = new Builder().build(new File("original.xml"));
handleNode(document.getRootElement());
System.out.println(document.toXML()); // empty elements now removed
}
private static void handleNode(Node node) {
if (node.getChildCount() == 0 && "".equals(node.getValue())) {
node.getParent().removeChild(node);
return;
}
// recurse the children
for (int i = 0; i < node.getChildCount(); i++) {
handleNode(node.getChild(i));
}
}
}
Questo probabilmente non in grado di gestire tutti i casi d'angolo correttamente, come un documento completamente vuoto. E cosa fare degli elementi che sono altrimenti vuoti ma hanno attributi?
Se si desidera salvare i tag XML con attributi, possiamo aggiungere nel metodo 'handleNode' il seguente controllo:
... && ((Element) node).getAttributeCount() == 0))
Inoltre, se l'XML ha due o più tag vuoti, uno dopo l'altro; questo metodo ricorsivo non rimuove tutti i tag vuoti!
(Questa risposta è parte della mia valutazione di XOM come un potenziale replacement to dom4j.)
Sono attualmente l'analisi del codice XML in strutture di dati in qualche modo particolare (JDOM, ecc)? O stai partendo da zero? –
Typo in XML XML: structure1 non è chiuso correttamente – Jonik