OLE Excel AutoFilter

OLE Excel AutoFilter

am 10.09.2006 22:28:19 von Kenny

Function AutoFilter([Field], [Criteria1], [Operator As
XlAutoFilterOperator = xlAnd], [Criteria2], [VisibleDropDown])

Is there a way to filter out only columns that have values? (NonBlanks)
from Filter?

use Win32::OLE;
use strict;

my $EXCEL = Win32::OLE->new('Excel.Application','Quit');
$EXCEL->{'Visible'} = 1;


my $Workbook = $EXCEL->Workbooks->Open("C:\\Ex\\Test3.xls");

my $SheetSelect = $Workbook->Sheets("A");
$SheetSelect->Select;
my $Current_Sheet = $Workbook -> ActiveSheet;


# set bold & color
my $row=2;
my $value = $SheetSelect -> Range("B".$row) -> {'Value'};
while($value =~ /\w+/) {
my $colorRange = $SheetSelect->Range("B".$row.":C".$row);
$colorRange->{Font}->{Bold} = 1 ;
$colorRange->Interior->{ColorIndex} = 4;

$row++;
$value = $SheetSelect -> Range("B".$row) -> {'Value'};
}

# set auto fit & filter (display drop down menu list)
my $autoFit = $SheetSelect->Range("B2:C40");;
$autoFit->Columns()->Autofit();
###This is part where I am having problem.. I want to show only
NonBlanks
$autoFit->Columns()->AutoFilter("B:C","(NonBlanks)");


## Save
$EXCEL->ActiveWorkbook->Save();
$Workbook->Save();
$Workbook->Quit();
Win32::OLE->FreeUnusedLibraries();

Re: OLE Excel AutoFilter

am 10.09.2006 23:13:37 von Kenny

> ###This is part where I am having problem.. I want to show only
> NonBlanks
> $autoFit->Columns()->AutoFilter("B:C","(NonBlanks)");
>


I can filter the specific value such as

$autoFit->Columns()->AutoFilter("1","100");

This will display the row it has 100 as the value. I just want to
display NonBlanks only but it doesn't work. Any help?

$autoFit->Columns()->AutoFilter("1","NonBlanks");
$autoFit->Columns()->AutoFilter("1","(NonBlanks)");