
エクセルのマクロがうまく動かないので、教えてください。
あるセルにカーソルをおいて、そのセルの文字を含んだ文字で(ワイルドカードを使って)オートフィルタ処理をしたいのですが、
「構文エラー」となってしまいます。
Dim num As String
num = ActiveCell.Value
Sheets("リスト").Select
Columns("AN:AN").Select
Selection.AutoFilter
Selection.AutoFilter Field:=1, Criteria1:="=*"&num&"*", Operator:=xlAnd
ActiveWindow.ScrollColumn = 2
Range("A1").Select
Criteria1:="=*"&num&"*"の部分で
「構文エラー」になっているようなのですが…
お分かりになる方教えてください。よろしくお願いします。
No.1ベストアンサー
- 回答日時:
こんにちは。
特に、そこ自体に問題ないというか、
VBAの特徴なのですが、「&」の前後に半角スペースが必要です。
"=*"&num&"*"
↓
"=*" & num & "*"
細かいことですが、この「*」アステリク を入れるというのは、対象も文字列ですから、数字が入れば、被検索対象列は、文字列でないといけないはずです。
Columns("AN:AN").Select
また、通常、このような選択をするというのは、飛び石になっている途中の空白も含むという意味になります。ただし、データ列の最後尾から下のセルは含まれません。
Range("AN1").CurrentRegion となります。特に、CurrentRegion がなくても動作的には同じです。
-------------------------------------------------
Dim num As String
num = ActiveCell.Value
Sheets("リスト").Select
'Columns("AN:AN").Select ←不要
Range("AN1").CurrentRegion.AutoFilter Field:=1, Criteria1:="=*" & num & "*", Operator:=xlAnd
'ActiveWindow.ScrollColumn = 2 ←不要
'Range("A1").Select ←不要
-------------------------------------------------
No.3
- 回答日時:
#2です。
数字文字列の場合うまくいくか心配になって。OKのようです。
シングルコーテイションを先頭に入れ数字入力ても、文字列書式にして入力しても。
例データ
計数
123
2312
2345
1222
43111
Sub test03()
Dim num As String
num = ActiveCell.Value
cr = "*" & "23" & "*"
Sheets("sheet3").Cells.AutoFilter
Sheets("sheet3").Cells.AutoFilter Field:=1, Criteria1:=cr
End Sub
結果
計数
123
2312
2345
ついでに、クライテリアの=は、=の場合に限り、省けるようです。
No.2
- 回答日時:
例データ
A列
山田 太郎
植田 太吉
近藤 茂
鈴木 健太郎
小野 正治
太田 恵子
大田
Sub test03()
Dim num As String
num = ActiveCell.Value
cr = "*" & "太" & "*"
Sheets("sheet1").Cells.AutoFilter
Sheets("sheet1").Cells.AutoFilter Field:=1, Criteria1:=cr
End Sub
で
A列
山田 太郎
植田 太吉
鈴木 健太郎
太田 恵子
にないました。
#1でおっしゃっている&の前後スペースが原因でしょうか。
実行時にエラー指摘が出るようになっていたように思いますが。
Select、Selectionは省いて簡潔に。
Sheets("sheet1").Cells.AutoFilterはフィルタモードを解除の為に入れています。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) データのある範囲を選択するVBAについて 2 2022/09/03 00:20
- Visual Basic(VBA) エクセルのマクロで対象ごとにシート分けしてその内容をセルに書き込みたい 9 2022/08/24 13:23
- Excel(エクセル) ExcelVBAについて。 2 2022/12/10 20:08
- Visual Basic(VBA) Sheet2の日付をキーにオートフィルターで2023年1月のデータを抽出し、Sheet3へ書き出すた 2 2023/03/06 23:57
- Excel(エクセル) VBA フォルダ見える化のコードについて 2 2023/06/19 15:04
- Visual Basic(VBA) excelVBAについて。 4 2022/11/21 16:15
- Excel(エクセル) Excleマクロ セル値の代入と文字列の結合について 3 2022/10/05 16:47
- Visual Basic(VBA) エクセル VBA 処理スピードを上げたいのですが。 6 2023/03/31 20:52
- Excel(エクセル) excelVBAについて。 8 2022/12/11 13:47
- Visual Basic(VBA) excelVBAについて。 1 2022/11/30 06:16
このQ&Aを見た人はこんなQ&Aも見ています
-
数値をワイルドカードでフィルタしたい
Excel(エクセル)
-
Excelオートフィルタで複数のセルの値を参照して抽出したい
Excel(エクセル)
-
マクロ オートフィルタの検索値を所定のセルから参照
Excel(エクセル)
-
-
4
vba フィルター 複数条件 3つ以上 完全一致除外
Visual Basic(VBA)
-
5
エクセルVBAで5行目からオートフィルタモードに設定したいたい
Excel(エクセル)
-
6
Excel VBAでオートフィルタで抽出した列データを別シートの最終行にコピーするには
Visual Basic(VBA)
-
7
【VBA】特定の値が入った行をコピーして別シートに貼り付ける方法をおしえていただきたいです。
Excel(エクセル)
-
8
オートフィルターをかけ、#N/A以外で絞込みするVBA記述をご教示ください
Excel(エクセル)
-
9
VBAで先月、先々月を求める方法
Visual Basic(VBA)
-
10
Offsetで可視セルだけを移動したい。
Excel(エクセル)
-
11
オートフィルタのリストを順番に印刷できるマクロ
Windows Vista・XP
-
12
excelのマクロで該当処理できなければ飛ばして進むにはどうすればよいのでしょうか
Visual Basic(VBA)
-
13
複数のマクロボタンをまとめて一つのマクロボタンにするということ。
Excel(エクセル)
-
14
VBA Cのセルが空白でなかったら、Aのセルに順番に数値を入力
Visual Basic(VBA)
-
15
【VBA】特定の文字が入っている行の一部を抽出して別シートコピーするには
Visual Basic(VBA)
-
16
VBAでの Replace関数で、ワイルドカードは使えないのでしょうか?
Visual Basic(VBA)
-
17
ワイルドカード「*」を使うとうまくいかないマクロの添削をお願いします
Visual Basic(VBA)
-
18
VBA 何かしら文字が入っていたら
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
EXCELで2つの数値のうち大きい...
-
エクセルで、2種類のデータを...
-
桁の違う数値での並び替え
-
エクセルで特定の文字が入って...
-
Excelで中央揃えが出来ない?
-
Excelの結合でA列とB列の内容...
-
Excel 指定行までコピーをおこ...
-
連続データを1行おきに貼り付け...
-
エクセルに入力した文字列に句...
-
Excelで同じ数字を縦に増やす方法
-
Excel2013 カラースケールを別...
-
excelで、1つのセルに入ってい...
-
エクセルで数値と文字が入った...
-
エクセル、11と1の区別
-
Excel強制終了
-
【EXCEL】別シートに同じ番号が...
-
エクセルで換算表を利用したい...
-
Excelで%表示を全角にしたいの...
-
エクセルの1つのセル内にある...
-
エクセルで、数字列の中にハイ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
EXCELで2つの数値のうち大きい...
-
エクセルで、2種類のデータを...
-
Excel強制終了
-
Excelで中央揃えが出来ない?
-
エクセルで特定の文字が入って...
-
桁の違う数値での並び替え
-
エクセルのまとめてカッコをつ...
-
Excel 指定行までコピーをおこ...
-
Excel 頭に「0」がついている...
-
数値の列から偶数のみを抽出す...
-
excelで、1つのセルに入ってい...
-
Excelの結合でA列とB列の内容...
-
エクセルに入力した文字列に句...
-
エクセルの関数
-
エクセルで、数字列の中にハイ...
-
Excel2013 カラースケールを別...
-
セル内文章から、英数字のみ取...
-
VLOOKUPのあいまい検索(スペー...
-
WEEKDAY 空白も7になってしまう
-
連続データを1行おきに貼り付け...
おすすめ情報