NamedRange.AdvancedFilter メソッド
抽出条件の範囲に基づいて、リストからデータをフィルター処理するかコピーします。
名前空間: Microsoft.Office.Tools.Excel
アセンブリ: Microsoft.Office.Tools.Excel (Microsoft.Office.Tools.Excel.dll 内)
構文
'宣言
Function AdvancedFilter ( _
Action As XlFilterAction, _
CriteriaRange As Object, _
CopyToRange As Object, _
Unique As Object _
) As Object
Object AdvancedFilter(
XlFilterAction Action,
Object CriteriaRange,
Object CopyToRange,
Object Unique
)
パラメーター
- Action
型 : Microsoft.Office.Interop.Excel.XlFilterAction
次のいずれかの XlFilterAction 値です。
xlFilterCopy
xlFilterInPlace
- CriteriaRange
型 : System.Object
抽出条件の範囲を指定します。この引数を省略した場合、抽出条件はありません。
- CopyToRange
型 : System.Object
Action が xlFilterCopy の場合、行のコピー先の範囲を指定します。それ以外のときには、この引数は無視されます。
- Unique
型 : System.Object
重複しないレコードのみをフィルター処理する場合は true を指定します。条件を満たすすべてのレコードをフィルター処理する場合は false を指定します。既定値 false です。
戻り値
型 : System.Object
解説
最初の選択が単一のセルの場合、そのセルの現在の領域が使用されます。
省略可能なパラメーター
省略可能なパラメーターについては、「Office ソリューションの省略可能なパラメーター」を参照してください。
例
次のコード例は、A1 ~ A5 のセル範囲に整数値を設定し、AdvancedFilter メソッドを使用して、値をフィルター処理し、B1 から始まるセル範囲にコピーします。
この例は、ドキュメント レベルのカスタマイズ用に作成されています。
Private Sub ActivateAdvancedFilter()
Dim namedRange1 As Microsoft.Office.Tools.Excel.NamedRange _
= Me.Controls.AddNamedRange(Me.Range("A1", "A5"), _
"namedRange1")
Me.Range("A1").Value2 = 10
Me.Range("A2").Value2 = 10
Me.Range("A3").Value2 = 20
Me.Range("A4").Value2 = 10
Me.Range("A5").Value2 = 30
namedRange1.AdvancedFilter(Excel.XlFilterAction.xlFilterCopy, , _
Me.Range("B1"), True)
End Sub
private void ActivateAdvancedFilter()
{
Microsoft.Office.Tools.Excel.NamedRange namedRange1 =
this.Controls.AddNamedRange(this.Range["A1", "A5"],
"namedRange1");
this.Range["A1"].Value2 = 10;
this.Range["A2"].Value2 = 10;
this.Range["A3"].Value2 = 20;
this.Range["A4"].Value2 = 10;
this.Range["A5"].Value2 = 30;
namedRange1.AdvancedFilter(Excel.XlFilterAction.xlFilterCopy,
this.Range["B1"], true);
}
.NET Framework セキュリティ
- 直前の呼び出し元に対する完全な信頼。このメンバーは、部分的に信頼されているコードから使用することはできません。詳細については、「部分信頼コードからのライブラリの使用」を参照してください。