Запрос областей ячеек, привязанных к пути XML отображения, с использованием метода Worksheet.XmlMapQuery

Возможные сценарии использования

Вы можете запрашивать области ячеек, сопоставленные пути XML-карты, с помощью метода Worksheet.xmlMapQuery(). Если путь существует, он вернет список областей ячеек, связанных с этим путем внутри XML-карты. Первый параметр метода Worksheet.xmlMapQuery() указывает путь элемента XML и второй параметр указывает XML-карту, которую вы хотите запросить.

Запрос областей ячеек, привязанных к пути XML-отображения, с использованием метода Worksheet.XmlMapQuery

На следующем снимке экрана показан Microsoft Excel, отображающий XML-карту внутри образцового файла Excel, использованного в коде. Код запрашивает XML-карту два раза и печатает список областей ячеек, возвращенных методом Worksheet.xmlMapQuery(), на консоль, как показано ниже.

todo:image_alt_text

Образец кода

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java
//Load sample Excel file having Xml Map
Workbook wb = new Workbook("sampleXmlMapQuery.xlsx");
//Access first XML Map
XmlMap xmap = wb.getWorksheets().getXmlMaps().get(0);
//Access first worksheet
Worksheet ws = wb.getWorksheets().get(0);
//Query Xml Map from Path - /MiscData
System.out.println("Query Xml Map from Path - /MiscData");
ArrayList ret = ws.xmlMapQuery("/MiscData", xmap);
//Print returned ArrayList values
for (int i = 0; i < ret.size(); i++)
{
System.out.println(ret.get(i));
}
System.out.println("");
//Query Xml Map from Path - /MiscData/row/Color
System.out.println("Query Xml Map from Path - /MiscData/row/Color");
ret = ws.xmlMapQuery("/MiscData/row/Color", xmap);
//Print returned ArrayList values
for (int i = 0; i < ret.size(); i++)
{
System.out.println(ret.get(i));
}

Вывод в консоль

Query Xml Map from Path - /MiscData

Aspose.Cells.CellArea(A1:A8)[0,0,7,0]

Aspose.Cells.CellArea(B1:B8)[0,1,7,1]

Aspose.Cells.CellArea(C1:C8)[0,2,7,2]

Aspose.Cells.CellArea(D1:D8)[0,3,7,3]

Aspose.Cells.CellArea(E1:E8)[0,4,7,4]

Query Xml Map from Path - /MiscData/row/Color

Aspose.Cells.CellArea(D1:D8)[0,3,7,3]

Получение пути XML из объекта списка/таблицы

XML-данные могут быть импортированы в листы. Иногда требуется путь XML из ListObjects листа. Эта функция доступна в Excel с помощью выражения вроде Sheet1.ListObjects(1).XmlMap.DataBinding. Та же функция доступна в Aspose.Cells при вызове ListObject.getXmlMap().getDataBinding().getUrl(). Следующий пример демонстрирует эту функцию. Файл шаблона и другие исходные файлы можно загрузить по следующим ссылкам:

  1. XMLData.xlsx
  2. CountryList.xml
  3. FoodList.xml
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java
// Load XLSX file containing data from XML file
Workbook workbook = new Workbook("XML Data.xlsx");
// Access the first worksheet
Worksheet ws = workbook.getWorksheets().get(0);
// Access ListObject from the first sheet
ListObject listObject = ws.getListObjects().get(0);
// Get the url of the list object's xml map data binding
String url = listObject.getXmlMap().getDataBinding().getUrl();
// Display XML file name
System.out.println(url);