
いつも助けていただきありがとうございます。
再質問です。(内容をまとめました。)
Excel2003でデータベースを作成しました。
「日付」(B列)のところには、2008/11/18という形式で入力しています。
VBAで抽出用フォームから「○○○○年○月○日~○○○○年○月○日までを抽出」として、
該当レコードを抽出するにはどうしたらよいでしょうか?
いろいろ試してはみたのですが、よい方法・アイディアができませんでした。
VBA初心者です。よろしくお願いします。
ちなみに試してみたのは、
期間抽出用フォームで、期間の始めと終わりの西暦・月・日をそれぞれ入力すると、いったんそれぞれのセルに入力され、
v5(開始月日用のセル)=T4&"/"&U4&"/"&V4(西暦・月・日がいったん入るセル)
t5(終了月日用のセル)=W4&"/"&X4&"/"&Y4
としました。(表示では2008/11/19となりました。)
そして、
Selection.AutoFilter
Selection.AutoFilter Field:=2, Criteria1:=">=range("v5")", Operator:=xlAnd _
, Criteria2:="<=range("y5")"
としたところ、エラーになりました。
どのように修正すればよいでしょうか?
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
このページを参考にしてみてください。
このサイトは初心者にお勧めです。
一通り目を通せば、ちょっとしたデータベースは簡単に作れるようになります。
参考URL:http://www.mahoutsukaino.com/ac/ac2000/ac2000/fu …
No.2
- 回答日時:
と同じ質問でしょう。そういう場合、そちらの質問を締めるものですよ。
私は質問文のレベルから、もっと考えやすい提案をしたのだが、質問者は主旨を理解してなかったようだ。
フィルタでやるのもよいが初心者にはVBAでは難しい面はある。
(1)テキストボックスで「から・まで」の期間を入れさせると、答えは文字列で返る。これを日付シリアル値にしないといけない。この点わかってますか。
(2)>いったんそれぞれのセルに入力され、
ここが初心者らしい。変数に日付シリアル値を保持すればよいのだ。
本件では条件は文字列で指定しないとダメだが。
それに年・月・日を3つのテキストに分けないほうがやりやすいと思うが、好みかな。
初心者のうちは、条件をセルに入れさせるようにするのが良いと思う。
他人に使わせるのかな。初心者のうちから、他人に使わせる処理を
VBAでやるのは何かと難しいよ。
ーー
テキストボックスを2つ(「から」と「まで」の日付を入れるもの)
コマンドボタンを1つ(検索開始)
を、フォームに設けて
Private Sub CommandButton1_Click()
ft = TextBox1.Text
tt = TextBox2.Text
f = DateValue(ft)
t = DateValue(tt)
sf = Format(f, "yyyy/mm/dd")
st = Format(t, "yyyy/mm/dd")
MsgBox sf & "-" & st
d = Range("A65536").End(xlUp).Row
Range("A1:B" & d).Select
'-----
Selection.AutoFilter
Selection.AutoFilter Field:=1, Criteria1:=">" & sf, Operator:=xlAnd, Criteria2:="<" & st
End Sub
ーー
上記は、フィルタのマクロの記録が中心になっている。その点難しいことは無い。その他VBAについての総合的な経験が要る。
ーーー
日付チェック
オートフィルタの解除
指定日を含むかどうかで、どう演算子を変えるか
など勉強のこと。
No.1
- 回答日時:
>Criteria1:=">=range("v5")"
パラメータ全てを””で囲んで仕舞えば、文字列として扱われてしまいます。
Criteria1:=">=" & range("v5")
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(データベース) Accessフォームからパラメーターで表示したレコードを指定のExcelのセルへ転送する方法について 2 2022/08/22 18:04
- Visual Basic(VBA) 前回ご教授いただいたコードに覚えたてのループ処理で品名りんごAから順に20回for nextでループ 7 2023/01/13 22:01
- Visual Basic(VBA) Sheet2の日付をキーにオートフィルターで2023年1月のデータを抽出し、Sheet3へ書き出すた 2 2023/03/06 23:57
- Visual Basic(VBA) access count数を変数に格納 2 2022/03/30 19:21
- Visual Basic(VBA) Sheet2からオートフィルターで売上日を抽出した件数をカウントし、その件数をSheet1のセルB1 2 2023/01/12 12:24
- Excel(エクセル) Excel VBAどこが間違ってますか? 4 2023/07/17 10:04
- Visual Basic(VBA) 【再投稿】VBAのシフト表でバグが出て困っています 3 2022/09/24 08:29
- Visual Basic(VBA) Excel VBA マクロ ある列の最終行迄を参照し、別の列の空白セルに値を入力したいです 2 2023/03/05 02:44
- Visual Basic(VBA) VBA ドロップダウンリストを残して値のみクリア 2 2022/10/27 05:42
- Excel(エクセル) Excel 売上管理シートに入力した売上データを、日報に自動反映させたいと考えています。 売上管理シ 3 2023/04/29 18:08
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelに入力した個々の日付の数...
-
31:30:00が1900/1/1 7:30:0
-
入力後に日付順になるように自...
-
エクセルでENTERを押すと数式が...
-
日付だけを変更して印刷(Excel)
-
Excelで半年後の日付を計算したい
-
Excelで8/26等の日付を全てその...
-
エクセルで数字列の間に『/』を...
-
エクセル関数で日付かどうかの...
-
EXCELで直近の日付を抽出する関数
-
エクセル セルに109と入力する...
-
エクセル 当番表の作り方 エク...
-
☆Excelエクセルで入力した日の...
-
ワード差込について
-
【マクロ】A列にある、日付(本...
-
日付を入力したセルをファイル...
-
WORDで翌日や翌々日の日付を表...
-
エクセルで1年後の月末を表示さ...
-
日付の照合でFALSEになります。
-
エクセル表からある項目と同じ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【マクロ】A列にある、日付(本...
-
Excelに入力した個々の日付の数...
-
日付だけを変更して印刷(Excel)
-
Excelで半年後の日付を計算したい
-
エクセルでENTERを押すと数式が...
-
31:30:00が1900/1/1 7:30:0
-
入力後に日付順になるように自...
-
Excelで8/26等の日付を全てその...
-
エクセルで数字列の間に『/』を...
-
エクセル 当番表の作り方 エク...
-
エクセルで日付入力欄を作成し...
-
ファイルのオープン時に今日の...
-
エクセル関数で日付かどうかの...
-
エクセルで1年後の月末を表示さ...
-
EXCELで直近の日付を抽出する関数
-
エクセル グラフ 軸の日付表記...
-
excelで月末日を判定したい
-
WORDで翌日や翌々日の日付を表...
-
ワード差込について
-
日付の照合でFALSEになります。
おすすめ情報