Apache Poi- 使用Java通过值筛选器而不是标签筛选器筛选数据透视表

huangapple go评论80阅读模式
英文:

Apache Poi- Filter a Pivot Table Using the Value Filters instead of the Label Filters using Java

问题

以下是您提供的代码的翻译部分:

package com.tutorialspoint.spring;
import java.io.FileOutputStream;

import org.apache.poi.ss.*;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.*;
import org.apache.poi.xssf.usermodel.*;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTAutoFilter;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCustomFilter;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCustomFilters;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTDataField;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTDataFields;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTFilter;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTFilterColumn;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTFilters;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotField;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.STFilterOperator;

import java.util.GregorianCalendar;

class CreatePivotTableFilter {

 public static void main(String[] args) throws Exception {

  try (Workbook workbook = new XSSFWorkbook();
       FileOutputStream fileout = new FileOutputStream("MyExcelV2.xlsx") ) {

   DataFormat format = workbook.createDataFormat();
   CellStyle dateStyle = workbook.createCellStyle();
   dateStyle.setDataFormat(format.getFormat("M/d/yy"));
   Sheet sheet = workbook.createSheet();
   String[] headers = new String[]{"Column1", "Column2", "Date", "IntVal", "Count"};
   Row row = sheet.createRow(0);
   Cell cell;
   for (int c = 0; c < headers.length; c++) {
    cell = row.createCell(c); cell.setCellValue(headers[c]);
   }
   Object[][] data = new Object[][]{
    new Object[]{"A", "B1", new GregorianCalendar(2019, 0, 1),  2d},
    new Object[]{"A", "B2", new GregorianCalendar(2019, 0, 1),  4d},
    new Object[]{"B", "B1", new GregorianCalendar(2019, 0, 2),  1d},
    new Object[]{"B", "B2", new GregorianCalendar(2019, 0, 2),  7d},
    new Object[]{"A", "C1", new GregorianCalendar(2019, 0, 1),  5d},
    new Object[]{"A", "C2", new GregorianCalendar(2019, 0, 1),  5d},
    new Object[]{"B", "C1", new GregorianCalendar(2019, 0, 2), 2d},
    new Object[]{"B", "C2", new GregorianCalendar(2019, 0, 2),  8d}
   };
   for (int r = 0; r < data.length; r++) {
    row = sheet.createRow(r+1);
    Object[] rowData = data[r];
    for (int c = 0; c < rowData.length; c++) {
     cell = row.createCell(c);
     if (rowData[c] instanceof String) {
      cell.setCellValue((String)rowData[c]);
     } else if (rowData[c] instanceof GregorianCalendar) {
      cell.setCellValue((GregorianCalendar)rowData[c]);
      cell.setCellStyle(dateStyle);
     } else if (rowData[c] instanceof Double) {
      cell.setCellValue((Double)rowData[c]);
     }
     else if (rowData[c] instanceof Integer)
         cell.setCellValue((Integer) rowData[c]);
    }
   }

   XSSFPivotTable pivotTable = ((XSSFSheet)sheet).createPivotTable(
    new AreaReference("A1:D9",
    SpreadsheetVersion.EXCEL2007),
    new CellReference("F4"));
   pivotTable.addRowLabel(0);
   pivotTable.addRowLabel(1);
   pivotTable.addColLabel(2);
   pivotTable.addColumnLabel(DataConsolidateFunction.SUM, 3);
   pivotTable.addColumnLabel(DataConsolidateFunction.AVERAGE, 3);
   pivotTable.getCTPivotTableDefinition().setOutline(true);
   pivotTable.getCTPivotTableDefinition().setOutlineData(false);
   for (CTPivotField pf: pivotTable.getCTPivotTableDefinition().getPivotFields().getPivotFieldList())
   {
   	System.out.println("FOO");

   	pf.setOutline(true);
   	pf.setDefaultSubtotal(true);
   }
   org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotFilters filters =
    org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotFilters.Factory.newInstance();
    org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotFilter field = filters.addNewFilter();
   field.setId(0);
   field.setFld(1);
   field.setType(org.openxmlformats.schemas.spreadsheetml.x2006.main.STPivotFilterType.VALUE_LESS_THAN_OR_EQUAL);
   field.setStringValue1("3");
   CTFilterColumn myCol = field.addNewAutoFilter().addNewFilterColumn();
   CTCustomFilters myFilter2= myCol.addNewCustomFilters();
   CTCustomFilter custFilt = myFilter2.addNewCustomFilter();
   custFilt.setOperator(STFilterOperator.LESS_THAN_OR_EQUAL);
   custFilt.setVal("3");
     field.getAutoFilter().setRef("A1");
   field.getAutoFilter().getFilterColumnArray(0).setColId(0);
   System.out.println(sheet.getLastRowNum());
   System.out.println(pivotTable.getColLabelColumns());
   System.out.println(pivotTable.getCTPivotTableDefinition().getDataFields().toString());
   pivotTable.getCTPivotTableDefinition().setFilters(filters);
   workbook.write(fileout);
  }

 }
}

希望这对您有所帮助。如果您有任何其他翻译需求,请随时提问。

英文:

To whom it may concern,

I am currently stuck on trying to add a filter to a pivot table in java using excel which filters by the sum of the columns instead of by the labels. However, when I try and filter it by value, I instead get a pivot table with no filtering done at all. This is what the current table looks like, even when I try and do value filtering:

Apache Poi- 使用Java通过值筛选器而不是标签筛选器筛选数据透视表

And this is my code (this example is actually reproducible):

package com.tutorialspoint.spring;
import java.io.FileOutputStream;
import org.apache.poi.ss.*;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.*;
import org.apache.poi.xssf.usermodel.*;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTAutoFilter;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCustomFilter;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCustomFilters;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTDataField;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTDataFields;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTFilter;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTFilterColumn;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTFilters;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotField;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.STFilterOperator;
import java.util.GregorianCalendar;
class CreatePivotTableFilter {
public static void main(String[] args) throws Exception {
try (Workbook workbook = new XSSFWorkbook(); 
FileOutputStream fileout = new FileOutputStream(&quot;MyExcelV2.xlsx&quot;) ) {
DataFormat format = workbook.createDataFormat();
CellStyle dateStyle = workbook.createCellStyle();
dateStyle.setDataFormat(format.getFormat(&quot;M\\/d\\/yy&quot;));
Sheet sheet = workbook.createSheet();
String[] headers = new String[]{&quot;Column1&quot;, &quot;Column2&quot;, &quot;Date&quot;, &quot;IntVal&quot;, &quot;Count&quot;};
Row row = sheet.createRow(0);
Cell cell;
for (int c = 0; c &lt; headers.length; c++) {
cell = row.createCell(c); cell.setCellValue(headers[c]);
}
Object[][] data = new Object[][]{
new Object[]{&quot;A&quot;, &quot;B1&quot;, new GregorianCalendar(2019, 0, 1),  2d},
new Object[]{&quot;A&quot;, &quot;B2&quot;, new GregorianCalendar(2019, 0, 1),  4d},
new Object[]{&quot;B&quot;, &quot;B1&quot;, new GregorianCalendar(2019, 0, 2),  1d},
new Object[]{&quot;B&quot;, &quot;B2&quot;, new GregorianCalendar(2019, 0, 2),  7d},
new Object[]{&quot;A&quot;, &quot;C1&quot;, new GregorianCalendar(2019, 0, 1),  5d},
new Object[]{&quot;A&quot;, &quot;C2&quot;, new GregorianCalendar(2019, 0, 1),  5d},
new Object[]{&quot;B&quot;, &quot;C1&quot;, new GregorianCalendar(2019, 0, 2), 2d},
new Object[]{&quot;B&quot;, &quot;C2&quot;, new GregorianCalendar(2019, 0, 2),  8d}
};
for (int r = 0; r &lt; data.length; r++) {
row = sheet.createRow(r+1);
Object[] rowData = data[r];
for (int c = 0; c &lt; rowData.length; c++) {
cell = row.createCell(c);
if (rowData[c] instanceof String) {
cell.setCellValue((String)rowData[c]);
} else if (rowData[c] instanceof GregorianCalendar) {
cell.setCellValue((GregorianCalendar)rowData[c]);
cell.setCellStyle(dateStyle);
} else if (rowData[c] instanceof Double) {
cell.setCellValue((Double)rowData[c]);
}
else if (rowData[c] instanceof Integer)
cell.setCellValue((Integer) rowData[c]);
}
}
XSSFPivotTable pivotTable = ((XSSFSheet)sheet).createPivotTable(
new AreaReference(&quot;A1:D9&quot;, 
SpreadsheetVersion.EXCEL2007), 
new CellReference(&quot;F4&quot;));
pivotTable.addRowLabel(0);
pivotTable.addRowLabel(1);
pivotTable.addColLabel(2);
pivotTable.addColumnLabel(DataConsolidateFunction.SUM, 3);
pivotTable.addColumnLabel(DataConsolidateFunction.AVERAGE, 3);
pivotTable.getCTPivotTableDefinition().setOutline(true);
pivotTable.getCTPivotTableDefinition().setOutlineData(false);
for (CTPivotField pf: pivotTable.getCTPivotTableDefinition().getPivotFields().getPivotFieldList())
{
System.out.println(&quot;FOO&quot;);
pf.setOutline(true);
pf.setDefaultSubtotal(true);
}
org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotFilters filters =
org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotFilters.Factory.newInstance();
org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotFilter field = filters.addNewFilter();
field.setId(0);
field.setFld(1);
field.setType(org.openxmlformats.schemas.spreadsheetml.x2006.main.STPivotFilterType.VALUE_LESS_THAN_OR_EQUAL);
field.setStringValue1(&quot;3&quot;);
CTFilterColumn myCol = field.addNewAutoFilter().addNewFilterColumn();
CTCustomFilters myFilter2= myCol.addNewCustomFilters();
CTCustomFilter custFilt = myFilter2.addNewCustomFilter();
custFilt.setOperator(STFilterOperator.LESS_THAN_OR_EQUAL);
custFilt.setVal(&quot;3&quot;);
field.getAutoFilter().setRef(&quot;A1&quot;);
field.getAutoFilter().getFilterColumnArray(0).setColId(0);
System.out.println(sheet.getLastRowNum());
System.out.println(pivotTable.getColLabelColumns());
System.out.println(pivotTable.getCTPivotTableDefinition().getDataFields().toString());
pivotTable.getCTPivotTableDefinition().setFilters(filters);
workbook.write(fileout);
}
}
}

Because this project is done with Java using Spring boot, these dependencies need to be added to the pom.xml file, if not done already:

		&lt;dependency&gt;
&lt;groupId&gt;org.apache.poi&lt;/groupId&gt;
&lt;artifactId&gt;poi-ooxml&lt;/artifactId&gt;
&lt;version&gt;4.1.2&lt;/version&gt;
&lt;/dependency&gt;
&lt;!-- https://mvnrepository.com/artifact/org.apache.poi/ooxml-schemas --&gt;
&lt;dependency&gt;
&lt;groupId&gt;org.apache.poi&lt;/groupId&gt;
&lt;artifactId&gt;ooxml-schemas&lt;/artifactId&gt;
&lt;version&gt;1.4&lt;/version&gt;
&lt;/dependency&gt;
&lt;dependency&gt;
&lt;groupId&gt;org.apache.poi&lt;/groupId&gt;
&lt;artifactId&gt;poi&lt;/artifactId&gt;
&lt;version&gt;4.1.2&lt;/version&gt;
&lt;/dependency&gt;

I know the code is really close to accessing the value filters, I think I forgot what I need to do to access them. Please help me!

答案1

得分: 1

主要问题在于您的代码为CTPivotFilter设置了StringValue1,但实际应该设置为IMeasureFld

内部的度量字段IMeasureFld设置了过滤器应该过滤的数据字段。在这种情况下,0是第一个具有数据汇总函数(求和)的数据字段。IMeasureFld 1将是第二个具有数据汇总函数(平均)的数据字段。

以下代码提供了一个最小工作示例。代码中有注释来解释不太明显的部分。

import java.io.FileOutputStream;

import org.apache.poi.ss.*;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.*;
import org.apache.poi.xssf.usermodel.*;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCustomFilter;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCustomFilters;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTDataField;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTFilter;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTFilterColumn;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.STFilterOperator;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotFilters;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotFilter;

import java.util.GregorianCalendar;

class CreatePivotTableFilter {

    public static void main(String[] args) throws Exception {

        try (Workbook workbook = new XSSFWorkbook(); 
             FileOutputStream fileout = new FileOutputStream("./MyExcelV2.xlsx")) {

            DataFormat format = workbook.createDataFormat();
            CellStyle dateStyle = workbook.createCellStyle();
            dateStyle.setDataFormat(format.getFormat("M/d/yy"));
            Sheet sheet = workbook.createSheet();
            String[] headers = new String[]{"Column1", "Column2", "Date", "IntVal", "Count"};
            Row row = sheet.createRow(0);
            Cell cell;
            for (int c = 0; c < headers.length; c++) {
                cell = row.createCell(c); cell.setCellValue(headers[c]);
            }
            Object[][] data = new Object[][]{
                new Object[]{"A", "B1", new GregorianCalendar(2019, 0, 1),  2d},
                new Object[]{"A", "B2", new GregorianCalendar(2019, 0, 1),  4d},
                new Object[]{"B", "B1", new GregorianCalendar(2019, 0, 2),  1d},
                new Object[]{"B", "B2", new GregorianCalendar(2019, 0, 2),  7d},
                new Object[]{"A", "C1", new GregorianCalendar(2019, 0, 1),  5d},
                new Object[]{"A", "C2", new GregorianCalendar(2019, 0, 1),  5d},
                new Object[]{"B", "C1", new GregorianCalendar(2019, 0, 2),  2d},
                new Object[]{"B", "C2", new GregorianCalendar(2019, 0, 2),  8d}
            };
            for (int r = 0; r < data.length; r++) {
                row = sheet.createRow(r+1);
                Object[] rowData = data[r];
                for (int c = 0; c < rowData.length; c++) {
                    cell = row.createCell(c);
                    if (rowData[c] instanceof String) {
                        cell.setCellValue((String)rowData[c]);
                    } else if (rowData[c] instanceof GregorianCalendar) {
                        cell.setCellValue((GregorianCalendar)rowData[c]);
                        cell.setCellStyle(dateStyle);
                    } else if (rowData[c] instanceof Double) {
                        cell.setCellValue((Double)rowData[c]);
                    } else if (rowData[c] instanceof Integer) {
                        cell.setCellValue((Integer) rowData[c]);
                    }
                }
            }

            XSSFPivotTable pivotTable = ((XSSFSheet)sheet).createPivotTable(
                new AreaReference("A1:D9", 
                SpreadsheetVersion.EXCEL2007), 
                new CellReference("F4"));
            pivotTable.addRowLabel(0);
            pivotTable.addRowLabel(1);
            pivotTable.addColLabel(2);
            pivotTable.addColumnLabel(DataConsolidateFunction.SUM, 3);
            pivotTable.addColumnLabel(DataConsolidateFunction.AVERAGE, 3);

            //create filters
            CTPivotFilters filters = CTPivotFilters.Factory.newInstance();

            //set custom value filter
            int filtersCount = 0; // to count filters
            CTPivotFilter filter = filters.addNewFilter();
            filter.setId(0); // filter needs Id
            filter.setFld(1); // filter on column B level
            filter.setType(org.openxmlformats.schemas.spreadsheetml.x2006.main.STPivotFilterType.VALUE_LESS_THAN_OR_EQUAL);
            filter.setIMeasureFld(0); //internal measure field is 0 (first data field) = Sum; 1 would be Average
            CTFilterColumn filterColumn = filter.addNewAutoFilter().addNewFilterColumn();
            filterColumn.setColId(0); // filterColumn need colId
            CTCustomFilters customFilters= filterColumn.addNewCustomFilters();
            CTCustomFilter customFilter = customFilters.addNewCustomFilter();
            customFilter.setOperator(STFilterOperator.LESS_THAN_OR_EQUAL);
            customFilter.setVal("3");

            filtersCount++;
            filters.setCount(filtersCount); // set filters count

            pivotTable.getCTPivotTableDefinition().setFilters(filters);

            workbook.write(fileout);
        }

    }
}

该代码生成的输出如下图所示:(图片略)

英文:

The main problem is that your code sets StringValue1 for CTPivotFilter. But it should set IMeasureFld.

The internal measure field IMeasureFld sets the data field on which the filter shall filter. In this case 0 is the first data filed having a data consolidate function -> Sum. IMeasureFld 1 would be the second data filed having a data consolidate function -> Average.

Following code provides a minimal working example. The code is commented where it is not self describing.

import java.io.FileOutputStream;
import org.apache.poi.ss.*;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.*;
import org.apache.poi.xssf.usermodel.*;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCustomFilter;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCustomFilters;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTDataField;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTFilter;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTFilterColumn;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.STFilterOperator;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotFilters;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPivotFilter;
import java.util.GregorianCalendar;
class CreatePivotTableFilter {
public static void main(String[] args) throws Exception {
try (Workbook workbook = new XSSFWorkbook(); 
FileOutputStream fileout = new FileOutputStream(&quot;./MyExcelV2.xlsx&quot;) ) {
DataFormat format = workbook.createDataFormat();
CellStyle dateStyle = workbook.createCellStyle();
dateStyle.setDataFormat(format.getFormat(&quot;M\\/d\\/yy&quot;));
Sheet sheet = workbook.createSheet();
String[] headers = new String[]{&quot;Column1&quot;, &quot;Column2&quot;, &quot;Date&quot;, &quot;IntVal&quot;, &quot;Count&quot;};
Row row = sheet.createRow(0);
Cell cell;
for (int c = 0; c &lt; headers.length; c++) {
cell = row.createCell(c); cell.setCellValue(headers[c]);
}
Object[][] data = new Object[][]{
new Object[]{&quot;A&quot;, &quot;B1&quot;, new GregorianCalendar(2019, 0, 1),  2d},
new Object[]{&quot;A&quot;, &quot;B2&quot;, new GregorianCalendar(2019, 0, 1),  4d},
new Object[]{&quot;B&quot;, &quot;B1&quot;, new GregorianCalendar(2019, 0, 2),  1d},
new Object[]{&quot;B&quot;, &quot;B2&quot;, new GregorianCalendar(2019, 0, 2),  7d},
new Object[]{&quot;A&quot;, &quot;C1&quot;, new GregorianCalendar(2019, 0, 1),  5d},
new Object[]{&quot;A&quot;, &quot;C2&quot;, new GregorianCalendar(2019, 0, 1),  5d},
new Object[]{&quot;B&quot;, &quot;C1&quot;, new GregorianCalendar(2019, 0, 2),  2d},
new Object[]{&quot;B&quot;, &quot;C2&quot;, new GregorianCalendar(2019, 0, 2),  8d}
};
for (int r = 0; r &lt; data.length; r++) {
row = sheet.createRow(r+1);
Object[] rowData = data[r];
for (int c = 0; c &lt; rowData.length; c++) {
cell = row.createCell(c);
if (rowData[c] instanceof String) {
cell.setCellValue((String)rowData[c]);
} else if (rowData[c] instanceof GregorianCalendar) {
cell.setCellValue((GregorianCalendar)rowData[c]);
cell.setCellStyle(dateStyle);
} else if (rowData[c] instanceof Double) {
cell.setCellValue((Double)rowData[c]);
}
else if (rowData[c] instanceof Integer)
cell.setCellValue((Integer) rowData[c]);
}
}
XSSFPivotTable pivotTable = ((XSSFSheet)sheet).createPivotTable(
new AreaReference(&quot;A1:D9&quot;, 
SpreadsheetVersion.EXCEL2007), 
new CellReference(&quot;F4&quot;));
pivotTable.addRowLabel(0);
pivotTable.addRowLabel(1);
pivotTable.addColLabel(2);
pivotTable.addColumnLabel(DataConsolidateFunction.SUM, 3);
pivotTable.addColumnLabel(DataConsolidateFunction.AVERAGE, 3);
//create filters
CTPivotFilters filters = CTPivotFilters.Factory.newInstance();
//set custom value filter
int filtersCount = 0; // to count filters
CTPivotFilter filter = filters.addNewFilter();
filter.setId(0); // filter needs Id
filter.setFld(1); // filter on column B level
filter.setType(org.openxmlformats.schemas.spreadsheetml.x2006.main.STPivotFilterType.VALUE_LESS_THAN_OR_EQUAL);
filter.setIMeasureFld(0); //internal measure field is 0 (first data field) = Sum; 1 would be Average
CTFilterColumn filterColumn = filter.addNewAutoFilter().addNewFilterColumn();
filterColumn.setColId(0); // filterColumn need colId
CTCustomFilters customFilters= filterColumn.addNewCustomFilters();
CTCustomFilter customFilter = customFilters.addNewCustomFilter();
customFilter.setOperator(STFilterOperator.LESS_THAN_OR_EQUAL);
customFilter.setVal(&quot;3&quot;);
filtersCount++;
filters.setCount(filtersCount); // set filters count
pivotTable.getCTPivotTableDefinition().setFilters(filters);
workbook.write(fileout);
}
}
}

It produces:

Apache Poi- 使用Java通过值筛选器而不是标签筛选器筛选数据透视表

huangapple
  • 本文由 发表于 2020年9月15日 04:18:47
  • 转载请务必保留本文链接:https://go.coder-hub.com/63891316.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定