加载工作簿或工作表时过滤对象

可能的使用场景

请用LoadOptions.LoadFilter从工作簿中筛选数据时的属性。但是如果你想从单个工作表中过滤数据,那么你将不得不覆盖LoadFilter.StartSheet方法。请提供适当的值加载数据过滤器选项创建或使用时的枚举加载过滤器.

加载数据过滤器选项枚举具有以下可能的值。

  • 全部
  • 书籍设置
  • 细胞空白
  • 单元布尔
  • 细胞数据
  • 细胞错误
  • 细胞数值
  • 单元串
  • 细胞价值
  • 图表
  • 条件格式
  • 数据验证
  • 定义名称
  • 文档属性
  • 公式
  • 超级链接
  • 合并区
  • 数据透视表
  • 设置
  • 形状
  • 表数据
  • 图纸设置
  • 结构
  • 风格
  • 桌子
  • VBA
  • XML地图

加载工作簿时过滤对象

以下示例代码说明了如何从工作簿中筛选图表。请检查示例 excel 文件用于此代码和输出 PDF由它产生。正如您在输出 PDF 中看到的那样,所有图表都已从工作簿中过滤掉。

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
// The path to the documents directory.
string dataDir = RunExamples.GetDataDir(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
// Create directory if it is not already present.
bool IsExists = System.IO.Directory.Exists(dataDir);
if (!IsExists)
System.IO.Directory.CreateDirectory(dataDir);
// Filter charts from the workbook.
LoadOptions lOptions = new LoadOptions();
lOptions.LoadFilter = new LoadFilter(LoadDataFilterOptions.All & ~LoadDataFilterOptions.Chart);
// Load the workbook with above filter.
Workbook workbook = new Workbook(dataDir + "sampleFilterCharts.xlsx", lOptions);
// Save worksheet to a single PDF page.
PdfSaveOptions pOptions = new PdfSaveOptions();
pOptions.OnePagePerSheet = true;
// Save the workbook in PDF format.
workbook.Save(dataDir + "sampleFilterCharts.pdf", pOptions);

加载工作表时过滤对象

下面的示例代码加载源文件并使用自定义过滤器从其工作表中过滤以下数据。

  • 它从名为 NoCharts 的工作表中过滤图表。
  • 它从名为 NoShapes 的工作表中过滤形状。
  • 它从名为 NoConditionalFormatting 的工作表中过滤条件格式。

一次,它加载源文件使用自定义过滤器,它会一张一张地拍摄所有工作表的图像。这是供您参考的输出图像。如您所见,第一张图片没有图表,第二张图片没有形状,第三张图片没有条件格式。

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
public class CustomLoadFilter : LoadFilter
{
public override void StartSheet(Worksheet sheet)
{
if (sheet.Name == "NoCharts")
{
//Load everything and filter charts
this.LoadDataFilterOptions = LoadDataFilterOptions.All & ~LoadDataFilterOptions.Chart;
}
if (sheet.Name == "NoShapes")
{
//Load everything and filter shapes
this.LoadDataFilterOptions = LoadDataFilterOptions.All & ~LoadDataFilterOptions.Drawing;
}
if (sheet.Name == "NoConditionalFormatting)")
{
//Load everything and filter conditional formatting
this.LoadDataFilterOptions = LoadDataFilterOptions.All & ~LoadDataFilterOptions.ConditionalFormatting;
}
}
}

这是根据工作表名称使用 CustomLoadFilter 类的方法。

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
public static void Run()
{
//Source directory
string sourceDir = RunExamples.Get_SourceDirectory();
//Output directory
string outputDir = RunExamples.Get_OutputDirectory();
// Filter worksheets using CustomLoadFilter class
LoadOptions loadOpts = new LoadOptions();
loadOpts.LoadFilter = new CustomLoadFilter();
// Load the workbook with filter defined in CustomLoadFilter class
Workbook workbook = new Workbook(sourceDir + "sampleCustomFilteringPerWorksheet.xlsx", loadOpts);
// Take the image of all worksheets one by one
for (int i = 0; i < workbook.Worksheets.Count; i++)
{
// Access worksheet at index i
Worksheet worksheet = workbook.Worksheets[i];
// Create an instance of ImageOrPrintOptions
// Render entire worksheet to image
ImageOrPrintOptions imageOpts = new ImageOrPrintOptions();
imageOpts.OnePagePerSheet = true;
imageOpts.ImageType = Drawing.ImageType.Png;
// Convert worksheet to image
SheetRender render = new SheetRender(worksheet, imageOpts);
render.ToImage(0, outputDir + "outputCustomFilteringPerWorksheet_" + worksheet.Name + ".png");
}
}