ワークシート.XmlMapQueryメソッドを使用して、XMLマップパスにマップされたセルエリアをクエリします。
可能な使用シナリオ
Aspose.Cellsを使用して、Worksheet.xmlMapQuery()メソッドを使ってXMLマップパスにマップされたセルエリアをクエリできます。パスが存在する場合、XMLマップ内のそのパスに関連するセルエリアのリストが返されます。Worksheet.xmlMapQuery()メソッドの最初のパラメータはXML要素パスを指定し、2番目のパラメータはクエリしたいXMLマップを指定します。
ワークシート.XmlMapQueryメソッドを使用して、XMLマップパスにマップされたセルエリアをクエリします。
次のスクリーンショットは、コードで使用されるsample Excelファイル内のMicrosoft ExcelがXMLマップを表示しています。コードはXMLマップを2回クエリし、コンソールに表示されるWorksheet.xmlMapQuery()メソッドによって返されるセルエリアのリストを以下のように出力します。
サンプルコード
// 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データはワークシートにインポートできます。ワークシートのListObjectsからXMLパスが必要な場合があります。この機能はSheet1.ListObjects(1).XmlMap.DataBindingのような式を使用することでExcelで利用できます。Aspose.Cellsでも、ListObject.getXmlMap().getDataBinding().getUrl()を呼び出すことで同じ機能を利用できます。次の例がこの機能を示しています。テンプレートファイルやその他のソースファイルは次のリンクからダウンロードできます。
// 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); |