Pivot Öğesinin mutlak konumunu belirleme
Contents
[
Hide
]
Bazen kullanıcının pivot öğelerinin mutlak konumunu belirtmesi gerekir, Aspose.Cells API birkaç yeni özellik ve bu kullanıcı ihtiyacını karşılamak için bir yöntem ortaya koymuştur.
- KatmaPivotItem.setPosition() üst düğümden bağımsız olarak tüm PivotItem’lerdeki konum dizinini belirtmek için kullanılabilen özellik. KatmaPivotItem.setPositionInSameParentNode() aynı üst düğüm altındaki PivotItems içindeki konum dizinini belirtmek için kullanılabilen özellik.
- Katma[PivotItem.move(int sayısı, boole isSameParent)](https://reference.aspose.com/cells/java/com.aspose.cells/pivotitem#move(int,%20boolean)yöntemi, sayım değerine bağlı olarak öğeyi yukarı veya aşağı taşımak için kullanılır; burada sayı, Özet Öğeyi yukarı veya aşağı hareket ettirmek için konumların sayısıdır. Sayım değeri sıfırdan küçükse, öğe yukarı taşınırken, sayım değeri sıfırdan büyükse, PivotItem aşağı hareket eder, taşıma işleminin aynı üst düğümde mi yoksa aynı üst düğümde mi gerçekleştirileceğini belirten Boolean isSameParent parametresi olumsuzluk.
- EskimişPivotItem.move(int sayısı) yöntemi, bu nedenle, yeni eklenen yöntemin kullanılması önerilir.PivotItem.move(int sayısı, boole isSameParent) yerine.
Lütfen dikkat, aramanız gerekir.PivotTable.refreshData vePivotTable.calculateData yöntemleri kullanmadan öncePivotItem.setPosition(), PivotItem.setPositionInSameParentNode() özellikler vePivotItem.move(int sayısı, boole isSameParent) yöntem.
Basit kod
Aşağıdaki örnek kod, bir Pivot Tablo oluşturur ve ardından aynı üst düğümdeki Pivot Öğeleri konumlarını belirtir.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java | |
// The path to the documents directory. | |
String dataDir = Utils.getDataDir(SpecifyAbsolutePositionOfPivotItem.class); | |
Workbook wb = new Workbook(dataDir + "source.xlsx"); | |
Worksheet wsPivot = wb.getWorksheets().add("pvtNew Hardware"); | |
Worksheet wsData = wb.getWorksheets().get("New Hardware - Yearly"); | |
// Get the pivottables collection for the pivot sheet | |
PivotTableCollection pivotTables = wsPivot.getPivotTables(); | |
// Add PivotTable to the worksheet | |
int index = pivotTables.add("='New Hardware - Yearly'!A1:D621", "A3", "HWCounts_PivotTable"); | |
// Get the PivotTable object | |
PivotTable pvtTable = pivotTables.get(index); | |
// Add vendor row field | |
pvtTable.addFieldToArea(PivotFieldType.ROW, "Vendor"); | |
// Add item row field | |
pvtTable.addFieldToArea(PivotFieldType.ROW, "Item"); | |
// Add data field | |
pvtTable.addFieldToArea(PivotFieldType.DATA, "2014"); | |
// Turn off the subtotals for the vendor row field | |
PivotField pivotField = pvtTable.getRowFields().get("Vendor"); | |
pivotField.setSubtotals(PivotFieldSubtotalType.NONE, true); | |
// Turn off grand total | |
pvtTable.setColumnGrand(false); | |
// Please call the PivotTable.RefreshData() and PivotTable.CalculateData(). Before using PivotItem.Position, | |
// PivotItem.PositionInSameParentNode and PivotItem.Move(int count, bool isSameParent). | |
pvtTable.refreshData(); | |
pvtTable.calculateData(); | |
pvtTable.getRowFields().get("Item").getPivotItems().get("4H12").setPositionInSameParentNode(0); | |
pvtTable.getRowFields().get("Item").getPivotItems().get("DIF400").setPositionInSameParentNode(3); | |
/* | |
* As a result of using PivotItem.PositionInSameParentNode,it will change the original sort sequence, // so when you use | |
* PivotItem.PositionInSameParentNode in another parent node,you need call the method named "CalculateData" again. | |
*/ | |
pvtTable.calculateData(); | |
pvtTable.getRowFields().get("Item").getPivotItems().get("CA32").setPositionInSameParentNode(1); | |
pvtTable.getRowFields().get("Item").getPivotItems().get("AAA3").setPositionInSameParentNode(2); | |
// Save file | |
wb.save(dataDir + "output.xlsx"); |