다음 예와 같이 XML에 네임스페이스가 포함된 경우:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <workbook xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships"> <sheets> <sheet name="Sheet1" sheetId="1" r:id="rId1"/> </sheets> </workbook>
"/workbook/sheets/sheet[1]"과 같은 XPath 쿼리를 사용할 때 문제가 발생할 수 있습니다. 이는 요소가 네임스페이스에 바인딩되어 있고 XPath가 기본 익명 네임스페이스에서 요소를 찾기 때문입니다.
다음이 있습니다. XPath 쿼리에서 네임스페이스를 처리하는 여러 가지 방법:
권장되는 접근 방식은 접두사로 네임스페이스를 등록하는 것입니다. 이를 통해 XPath 개발 및 유지 관리가 단순화됩니다.
NamespaceContext namespaceContext = new NamespaceContext() { @Override public String getNamespaceURI(String prefix) { if ("xssf".equals(prefix)) { return "http://schemas.openxmlformats.org/spreadsheetml/2006/main"; } return null; } @Override public String getPrefix(String namespaceURI) { return null; } @Override public Iterator getPrefixes(String namespaceURI) { return null; } }; XPath xpath = XPathFactory.newInstance().newXPath(); xpath.setNamespaceContext(namespaceContext);
이 설정을 사용하면 단순화된 XPath 쿼리를 사용할 수 있습니다.
/xssf:workbook/xssf:sheets/xssf:sheet[1]
네임스페이스 접두사를 사용하지 않으려는 경우 조건자 필터와 함께 일반 일치를 사용하는 XPath 표현식을 만들 수 있습니다.
/*[local-name()='workbook' and namespace-uri()='http://schemas.openxmlformats.org/spreadsheetml/2006/main'] /*[local-name()='sheets' and namespace-uri()='http://schemas.openxmlformats.org/spreadsheetml/2006/main'] /*[local-name()='sheet' and namespace-uri()='http://schemas.openxmlformats.org/spreadsheetml/2006/main'][1]
이 방법을 사용하면 확인하기 어려울 수 있는 자세한 XPath 표현식이 생성됩니다. 읽고 유지하세요.
또한 로컬 이름만 일치시켜 네임스페이스를 무시할 수도 있습니다.
/*[local-name()='workbook']/*[local-name()='sheets']/*[local-name()='sheet'][1]
그러나 이 접근 방식은 서로 다른 네임스페이스에서 동일한 로컬 이름을 사용하는 혼합 어휘의 경우 잘못된 요소를 선택할 위험이 있습니다.
위 내용은 XML에 네임스페이스가 포함된 경우 XPath 쿼리에서 네임스페이스를 어떻게 처리합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!