일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- oracle
- Docker
- 문서
- spring
- Source
- MySQL
- myBatis
- Open Source
- PostgreSQL
- SpringBoot
- jpa
- IntelliJ
- Tomcat
- JavaScript
- ubuntu
- 설정
- AJAX
- MSSQL
- Spring Boot
- Exception
- Thymeleaf
- STS
- JDBC
- error
- Eclipse
- 오픈소스
- git
- Python
- maven
- Core Java
- Today
- Total
헤르메스 LIFE
[Source] XML 파싱 본문
출처 : http://makerj.tistory.com/149
1. XML Document 생성
1.1 XML 불러오기 Case1> File로부터 읽는 경우 Document xml = DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(new File(filePath));
Case2> String으로부터 읽는 경우 Document xml = DocumentBuilderFactory.newInstance().newDocumentBuilder(). parse(new ByteArrayInputStream(xmlString.getBytes()));
1.2 정규화 xml.getDocumentElement().normalize();
2. XPath 생성
XPath는 XML노드들을 CSS다루듯이 쉽게 다루도록 도와주는 API입니다.
XPath xpath = XPathFactory.newInstance().newXPath();
3. 노드 선택
Case1> 단일 노드 선택 단 한개의 노드를 선택할 경우입니다. 만약 복수의 노드를 이 방법을 써서 선택할 경우 최초 노드만 선택됩니다.
// root 선택 Node node = xml.getDocumentElement();
// rss아래 channel아래에 위치한 generator 노드 선택 Node node = (Node) xpath.evaluate("//rss/channel/generator", xml, XPathConstants.NODE);
// Attribute에 따른 선택: id가 3인 product 노드 선택 Node node = (Node) xpath.evaluate("//product[@id='3']", xml, XPathConstants.NODE);
// 전체 city노드 중 첫번째 city 노드만 선택. 첫번째 항목 선택이지만 0이 아니라 1임에에 유의! Node node = (Node) xpath.evalutate("//city[1]", xml, XPathConstatns.NODE);
Case2> 복수 노드 선택 복수의 노드를 NodeList로 반환합니다.
// 모든 city 노드 선택 NodeList node = (NodeList) xpath.evaluate("//city", xml, XPathConstants.NODESET);
// Attribute에 따른 선택: wl_ver가 3이면 어떤 노드든지 다 선택 NodeList node = (NodeList) xpath.evaluate("//*[@wl_ver='3']", xml, XPathConstants.NODESET);
Case3> 자식 노드 선택 Node의 getChildNodes() 메소드는 자식 노드들을 NodeList타입으로 반환합니다.
// 예: 현재 선택된 노드가 Node타입이고 변수명이 node일 경우 NodeList childs = node.getChildNodes();
4. 선택한 노드 값 얻기
Node.getTextContent()는 선택한 노드의 값을 String형태로 반환합니다.
Case1> 선택된 단일 노드에서 값 얻기 node.getTextContent();
Case2> 선택된 복수 노드들에서 값 얻기 NodeList.item(int index)메소드는 해당 인덱스의 단일 노드를 돌려줍니다.
// NodeList타입의 node변수에서 반복을 통한 값 얻기 for (int i = 0; i < node.getLength(); ++i) { if(node.item(i).getNodeType() != Node.ELEMENT_NODE) continue; // 실제 NODE만 취급합니다 node.item(i).getTextContent(); // 얻은 값을 원하는 대로 다루면 되겠지요 }
XML 생성 및 저장
별도의 포스트로 작성하였습니다.
부록
디버그가 쉽게 '이름:값' 쌍으로 출력하기 Node node의 경우 System.out.println(node.getNodeName()+": "+node.getTextContent()); //예: city: seoul 식으로 나오겠지요
XPath참조 링크 http://viralpatel.net/blogs/java-xml-xpath-tutorial-parse-xml/
|
'Core Java' 카테고리의 다른 글
[Source] 문자열 관련 Sample (0) | 2020.12.22 |
---|---|
[Source] XML 만들기 (0) | 2020.12.20 |
[Source] Create Xml File Demo (0) | 2020.12.20 |
[Source] DOM4j Modify XMLDemo (0) | 2020.12.20 |
[Source] XPatharserDemo (0) | 2020.12.20 |