XPath 사용하는 방법.
간단한 XML 에디터를 만들어 가고 있는중에...
XPATH를 사용하면 훨씬더 쉽게 검색할 수 있다는 사실을 발견...
OTL 그럼 전에 캐 삽질 DOM 트리 검색은....0_0?
XPATH로 고치는거 고고싱? ㅠ_ㅠ
귀찮다 OTL...일단 에디터 다 만들고 생각해 봐야지 ..
TreeViewer로 구현
마음 같아서야 이클립스에 포함된 XML 에디터 처럼 만들고 싶지만..
아직 허접해서 -_-;;
저기 펼쳐져 있는 트리중에 사진자료에 새로운 사진 노드를 추가하는 것부터 시작..
XPATH를 사용해서 할려고 하기때문에.. 대 난관에 봉착했지만..
다행이 해결 -ㅁ-v
일단 추가는 됬으니 자질구레한거 정리해서 하면 될것 같다..
이제그만 각설하고 소스를 살펴보면
일단 주요 내용을 살펴보면
문서를 파싱한다.
XPath로 객채를 만든다.
XPath표현식을 작성한다.
검색한 결과를 object로 저장하고.
여기에 새 엘리멘트를 추가한다.
그리고 최종적으로 메모리에 올라가 있는 돔 을 파일에 쓴다.
DocumentBuilderFactory domFactory = DocumentBuilderFactory
.newInstance();
//domFactory.setNamespaceAware(true); // never forget this!
DocumentBuilder builder = domFactory.newDocumentBuilder();
Document doc = builder.parse("VirusInformation.xml");
XPath xpath = factory.newXPath();
XPathExpression expr = xpath.compile("//작물[@종류='채소']/병해/채소[@종류='오이']/병[@병명='노균병']/사진자료");
Object result = expr.evaluate(doc, XPathConstants.NODESET);
for (int i = 0; i < nodes.getLength(); i++) {
Element e = (Element)nodes.item(i);
Element newElement = doc.createElement("사진");
Text objText = doc.createTextNode("사진 추가 연습");
newElement.appendChild(objText);
newElement.setAttribute("파일명", "1300.jpg");
e.appendChild(newElement);
System.out.println(nodes.item(i));
}
// 메모리에 추가한후 파일에 다시 쓰기.
TransformerFactory tFactory = TransformerFactory.newInstance();
Transformer transformer;
try {
transformer = tFactory.newTransformer();
transformer.transform(new DOMSource(doc), new StreamResult(new FileOutputStream("VirusInformation.xml")));
} catch (TransformerConfigurationException e) {
e.printStackTrace();
} catch (TransformerException e) {
e.printStackTrace();
}
이런 형식으로?
아 오전내내 삽질해서 성공했구나. OTL