Содержание
В этом примере мы демонстрируем использование синтаксического анализатора DOM для изменения существующего XML-файла:
- Добавить новый элемент
- Обновить существующий атрибут элемента
- Обновить существующее значение элемента
- Удалить существующий элемент
1. XML-файл
Смотрите до и после XML-файла.
Файл: file.xml — оригинальный файл XML.
yong
mook kim
mkyong
100000
Позже обновите вышеуказанный XML-файл с помощью DOM XML Parser.
- Обновите атрибут персонала id = 2
- Обновить значение зарплаты до 200000
- Добавить новый элемент «возраст» под персоналом
- Удалить элемент «имя» под персоналом
Файл: file.xml — Недавно измененный файл XML.
mook kim
mkyong
2000000
28
2. DOM Parser
DOM XML parser для обновления вышеуказанного XML-файла.
import java.io.File;
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
public class ModifyXMLFile {
public static void main(String argv[]) {
try {
String filepath = "c:\file.xml";
DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder = docFactory.newDocumentBuilder();
Document doc = docBuilder.parse(filepath);
// Получить корневой элемент
Node company = doc.getFirstChild();
// Получить элемент staff, он может не работать, если в теге есть пробелы, или
// все странные символы впереди ... лучше использовать
// getElementsByTagName (), чтобы получить его напрямую.
// Узел персонала = company.getFirstChild ();
// Получить элемент staff по имени тега напрямую
Node staff = doc.getElementsByTagName("staff").item(0);
// обновляем атрибут персонала
NamedNodeMap attr = staff.getAttributes();
Node nodeAttr = attr.getNamedItem("id");
nodeAttr.setTextContent("2");
// добавляем новый узел к персоналу
Element age = doc.createElement("age");
age.appendChild(doc.createTextNode("28"));
staff.appendChild(age);
// цикл дочернего узла персонала
NodeList list = staff.getChildNodes();
for (int i = 0; i < list.getLength(); i++) {
Node node = list.item(i);
// получить элемент заработной платы и обновить значение
if ("salary".equals(node.getNodeName())) {
node.setTextContent("2000000");
}
// удалить имя
if ("firstname".equals(node.getNodeName())) {
staff.removeChild(node);
}
}
// записать содержимое в XML-файл
TransformerFactory transformerFactory = TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
DOMSource source = new DOMSource(doc);
StreamResult result = new StreamResult(new File(filepath));
transformer.transform(source, result);
System.out.println("Done");
} catch (ParserConfigurationException pce) {
pce.printStackTrace();
} catch (TransformerException tfe) {
tfe.printStackTrace();
} catch (IOException ioe) {
ioe.printStackTrace();
} catch (SAXException sae) {
sae.printStackTrace();
}
}
}
0.00 (0%) 0 votes