Дочерние узлы обработки XML в цикле с использованием Java
Может ли кто-нибудь помочь мне с кодом Java обработать этот XML и получить результат, упомянутый в конце. Заранее спасибо.
XML-файл:
<?xml version = "1.0"?>
<Oraganization Id="123" >
<state_name ID="1" name="Telangana">
<city_name ID="1" name="Hyderabad">
<school_name ID="1" school_name="Vidayalay_1">
<record>
<class>1</class>
<TeacheName>ABC</TeacheName>
<NumberOfStudents>100</NumberOfStudents>
</record>
<record>
<class>2</class>
<TeacheName>XYZ</TeacheName>
<NumberOfStudents>101</NumberOfStudents>
</record>
</school_name>
<school_name ID="2" school_name="Vidayalay_2">
<record>
<class>1</class>
<TeacheName>ABC</TeacheName>
<NumberOfStudents>100</NumberOfStudents>
</record>
<record>
<class>2</class>
<TeacheName>XYZ</TeacheName>
<NumberOfStudents>101</NumberOfStudents>
</record>
</school_name>
</city_name>
</state_name>
<state_name ID="2" name="Karnataka">
<city_name ID="1" name="Banglore">
<school_name ID="1" school_name="Bglr_Vidayalay_1">
<record>
<class>1</class>
<TeacheName>ABC</TeacheName>
<NumberOfStudents>100</NumberOfStudents>
</record>
<record>
<class>2</class>
<TeacheName>XYZ</TeacheName>
<NumberOfStudents>101</NumberOfStudents>
</record>
</school_name>
</city_name>
</state_name>
</Oraganization>
Ожидаемый результат:
StateId Name CityId Name SchoolID SchoolName class TeacherName NumberOfStudents
1 Телангана 1 Хайдарабад 1 Видайалай_1 1 ABC 100
1 Телангана 1 Хайдарабад 1 Видайалай_1 2 XYZ 101
1 Телангана 1 Хайдарабад 2 Видайалай_2 1 ABC 100
1 Телангана 1 Хайдарабад 2 Видайалай_2 2 XYZ 101
2 Карнатака 1 Банглор 1 Bglr_Vidayalay_1 1 ABC 100
2 Карнатака 1 Банглор 1 Bglr_Vidayalay_1 2 XYZ 100
1 ответ
Загрузите библиотеку XPath 3.1 (например, Saxon), а затем выполните выражение XPath
string-join(//record !
string-join(( ancestor::state_name ! (@ID, @name),
ancestor::city_name ! (@ID, @name),
ancestor::school_name ! (@ID, @school_name),
class, TeacheName, NumberOfStudents), ' '), '\n')
У кого-то может хватить терпения показать вам решение с использованием DOM, но я предпочитаю простой способ.