ExcelのVBAの質問になりますが、教えてください。
下記を動かすと最後の行で「'Range'メソッドは失敗しました: '_Worksheet' オブジェクト」と出ます
どうしても最後の行をセレクトしたいのですが、どうしたらよいでしょうか。
Option Explicit
Public WB1 As Workbook
Public WB1SH1 As Worksheet
Public CSVWB1 As Workbook
Public CSVWB1SH1 As Worksheet
Dim MaxRow As Integer
Private Sub CommandButton1_Click()
Set WB1 = ActiveWorkbook
Set WB1SH1 = WB1.Worksheets(1)
Dim a As String
a = WB1SH1.Range("a1)
Workbooks.Open "C:\Users\User\Desktop\" & a & ".CSV"
Set CSVWB1 = ActiveWorkbook
Set CSVWB1SH1 = CSVWB1.Worksheets(1)
MaxRow = CSVWB1SH1.Cells(Rows.Count, 1).End(xlUp).Row
WB1SH1.Activate
WB1SH1.Range(Cells(1, 1), Cells(MaxRow, 3)).Select
CSVWB1SH1.Activate
CSVWB1SH1.Range(Cells(1, 1), Cells(MaxRow, 3)).Select '←ここでエラーがでる
End Sub
No.1ベストアンサー
- 回答日時:
初心者さんが必ず一度は失敗します。
>Private Sub CommandButton1_Click()
のようにシートオブジェクトに記載したマクロでは、シートを修飾しないセル(レンジ)オブジェクトは全て「マクロを記載したシート」に紐付けられています。
CSVWB1SH1.Range(CSVWB1SH1.Cells(1, 1), CSVWB1SH1.Cells(MaxRow, 3)).Select
のようにしなければいけません。
keithin様
早々のご回答ありがとうございます。
回答をメールで確認できたおかげで午前中に出先で処理ができました。
見事動きました!!
自己流でコードを組んでいるためとても読みづらかったと思われるのに
的確なご指摘で驚きました。
自分では全く何がダメなのかわからず困り果てての質問だったため感動
しました。
本当にありがとうございました。
No.2
- 回答日時:
こんにちは。
私のように細かなことを言う人はいないかと思いますが、少し我慢してください。
Private Sub CommandButton1_Click()
ということは、シートモジュール(オブジェクトモジュール)ですね。
シートモジュール上で、Public ステートメントが使えません。
シートモジュールに、もし入れるなら、
Dim Wb1 As Workbook
Dim Wb1Sh1 As Worksheet
Dim CSVwb1 As Workbook
Dim CSVwb1Sh1 As Worksheet
Dim MaxRow As Integer
のようにしますが、ブックが閉じるまで、変数を抱えることになりますから、必要以上には、モジュールスコープ(=そのモジュールだけの範囲)でも、用いません。
Public ステートメントを使うなら、標準モジュールを使います。しかし、Public ステートメントは、慎重に使わないといけない書き方です。テキストには「グローバル変数(Public変数)はできる限り使わない」ということが書かれています。それは、プロジェクト全体に関わってきますので、通常、使っても、モジュール内だけにします。ちなみに、なぜ「グローバル」と呼ぶのか、少し疑問がつくのは、厳密には、複数のプロジェクト間には使えないからです。
それと、変数は、大文字・小文字を含めていれるというのが、標準的な記法です。そうすることによって、入力ミスを減らすわけです。大文字だけで書くのは、定数に限ります。
例:
'標準モジュール
Public Wb1 As Workbook
Public Wb1Sh1 As Worksheet
Public CSVwb1 As Workbook
Public CSVwb1Sh1 As Worksheet
また、VB6系では、Sub プロシージャ名の直下から、Dim の変数定義の宣言をまとめるというのが通例になっていますから、
Private Sub CommandButton1_Click()
Dim a As String '←ここに置く
Set Wb1 = ActiveWorkbook
Set Wb1Sh1 = WB1.Worksheets(1)
---------------------
Set Wb1 = ActiveWorkbook
Set Wb1Sh1 = Wb1.Worksheets(1)
実際は、このようには書きません。Worksheet("*****") を変数に入れた時に、すでに親オブジェクトの、Workbookも含まれていますから、2つにする必要はありません。
Set Wb1Sh1 = ActiveWorkbook.Worksheets(1) '←出来る限り、パラメータは、シート名にしてください。
だけで良いです。
----------------------
このコードは少し問題がありますから、正確には書けませんが、Rangeのパラメータで、Cells を2ついれることは、ふつうはしません。いずれにしても、なるべく、Withステートメントを使うようにしましょう。(オブジェクトの前に、ピリオド[.]が入っていますから、注意してください)
もちろん、前に変数を使って、コンテナ型(親オブジェクトから全部入れる)という方法も悪くはありませんが、VBAの書き方の基本は、文字数を少なくして、なおかつ可読性を悪くしないということです。
'//
With Wb1Sh1
.Activate
.Range(.Cells(1, 1), .Cells(MaxRow, 3)).Select
'前々行のActivate を含めて、実務上は、Activate やSelect はあまり使いません。これらのメソッドはユーザーに見せるために使うものです。
End With
With CSVwb1Sh1
.Activate
.Range(.Cells(1, 1), .Cells(MaxRow, 3)).Select 'こちらも同様です。
End With
'//
記法の参考資料です。今さらという人もいるかもしれませんが、私でも参考にしています。
コーディング技法(VS.Net 2003)
http://msdn.microsoft.com/ja-jp/library/aa291593 …
Microsoft Office 2000/Visual Basic プログラマーズ ガイド
http://msdn.microsoft.com/ja-jp/library/cc375992 …
私は、この書籍版を手に入れています。
面倒な話を長く書きましたが、少しずつ習得してみてください。信じないかもしれませんが、これを覚えればエラーが減り、自然と上達していきます。なお、インデント(桁下げ)は、mougで知られた渡辺さんという方の、VBePlus というツールを使っています。これも、エラーを発見するためです。
WindFaller様
ご指導、ありがとうござます。
初心者で独学の私にはとても勉強になりました。
>シートモジュール上で、Public ステートメントが使えません
>変数は、大文字・小文字を含めていれるというのが、標準的な記法です
>大文字だけで書くのは、定数に限ります
>Subプロシージャ名の直下から、Dim の変数定義の宣言をまとめるというのが通例
これらはどれも知りませんでした。。。
>親オブジェクトの、Workbookも含まれていますから、2つにする必要はありません。
2個も書く必要はないのですね!!少しコンパクトになります!
>なるべく、Withステートメントを使うようにしましょう
Withはとても苦手で避けているところが自分にあります。
もっと勉強して活用します。
記法の参考資料、Web版も参考になりますが、書籍版ももっと興味があります。
Web版を活用してみて自分にあっていそうだったら入手を考えてみます。
ご指導、ありがとうございました。感謝いたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAが止まります。 1 2022/09/02 14:51
- Visual Basic(VBA) 2つ目のコンボボックスが動作しません。 3 2023/03/25 12:29
- Excel(エクセル) VBAの指示の内容 昨日こちらでご教示頂いたのですが初心者な為、一つ一つの指示が何をやっているのかわ 2 2022/10/25 18:08
- Visual Basic(VBA) Sheet2からオートフィルターで売上日を抽出した件数をカウントし、その件数をSheet1のセルB1 2 2023/01/12 12:24
- Visual Basic(VBA) VBA 別ブックからの転記の高速化について VBA 別ブックからの転記の高速化についてご教授下さい。 19 2022/07/26 13:07
- Visual Basic(VBA) A列B列C列 3 2023/04/26 18:11
- Visual Basic(VBA) worksheets & rows メソッドは失敗しました。のエラー回避のやり方 1 2022/06/07 13:58
- Visual Basic(VBA) 【ご教示ください】VBAの記述方法がわかりません。 2 2022/08/12 21:28
- Visual Basic(VBA) VBA処理追加 こちらでご教示頂いたのですが回答完了させてしまいましたのでこちらからまた質問させてく 2 2022/10/27 09:57
- Visual Basic(VBA) ExcelVBAの転記について 1 2022/03/23 20:13
このQ&Aを見た人はこんなQ&Aも見ています
-
それもChatGPT!?と驚いた使用方法を教えてください
仕事やプライベートでも利用が浸透してきたChatGPTですが、こんなときに使うの!!?とびっくりしたり、これは画期的な有効活用だ!とうなった事例があれば教えてください!
-
秘密基地、どこに作った?
小さい頃、1度は誰もが作ったであろう秘密基地。 大人の今だからこそ言える、あなたの秘密基地の場所を教えてください!
-
【お題】ヒーローの謝罪会見
【大喜利】 怪人の侵略に気づくのが遅れ、それを防げなかった戦隊ヒーローの謝罪会見で出た発言
-
いけず言葉しりとり
はんなりと心にダメージを与える「いけず言葉」でしりとりをしましょう。 「あ」あら〜しゃれた服着てはりますな 遠くからでもわかりましたわ
-
好きな和訳タイトルを教えてください
洋書・洋画の素敵な和訳タイトルをたくさん知りたいです!【例】 『Wuthering Heights』→『嵐が丘』
-
マクロの「Rangeメソッドは失敗しました’Globalオブジェクト」エラーの解決方法について
Excel(エクセル)
-
Rangeメソッドは失敗しました。globalオブジェクトについて
Excel(エクセル)
-
Worksheets メソッドは失敗しました。のエラー処理のやり方
Visual Basic(VBA)
-
-
4
VBA 実行時エラー1004 rangeメソッドは失敗しました。globalオブジェクトのエラー
Excel(エクセル)
-
5
エクセルVBA 作業後に選択範囲を解除する方法
Excel(エクセル)
-
6
初歩的な事だと思います。 Sub または Function が定義されていません。
Visual Basic(VBA)
-
7
『実行時エラー'1001': 'Range'メソッドは失敗しました:'
Visual Basic(VBA)
-
8
VBAを何回も作り直して、容量が増えた
Excel(エクセル)
-
9
VBA たまに変数がempty値になるエラー
Excel(エクセル)
-
10
エクセルVBAでセルに入力したパスでブックを開く
Excel(エクセル)
-
11
VBAでセル入力の数式に変数を用いたい
Excel(エクセル)
-
12
VBAで繰り返しコピーしながら下へ移動させる方法
Excel(エクセル)
-
13
【Excel VBA】指定行以降をクリアするには?
Visual Basic(VBA)
-
14
グラフを表示するとき「’~’メソッドは失敗しました。」エラー発生
Visual Basic(VBA)
-
15
繰り返し1行~28行までを順順にコピーする方法
Visual Basic(VBA)
-
16
Excel:コマンドボタンの移動
Excel(エクセル)
-
17
VBAを使って検索したセルをコピーして別の場所に貼り付ける。
Visual Basic(VBA)
-
18
VBPをダブルクリックするとたまに「メソッドは失敗しました " オブジェクト」と出るのですが?
Visual Basic(VBA)
-
19
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
20
セルのコピーで「オブジェクトが必要です。」
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~12/2】 国民的アニメ『サザエさん』が打ち切りになった理由を教えてください
- ・ちょっと先の未来クイズ第5問
- ・【お題】ヒーローの謝罪会見
- ・これが怖いの自分だけ?というものありますか?
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Workbook.BeforeSave イベント...
-
VBA This Workbookモジュール...
-
Excel VBAで、ユーザーフォーム...
-
ユーザー定義関数に#NAME?が返...
-
Excel VBAでリンク切れをチェッ...
-
エクセルVBAでシートモジュール...
-
Excel VBA 『Call』で呼び出す...
-
VBAで旧字体を異字体に一括で変...
-
Access VBA標準モジュールにつ...
-
vba userFormのSubを標準モジュ...
-
モジュールの最大数はいくつな...
-
VBのフォームモジュールと標準...
-
クラスモジュールについて
-
モジュールとクラスの違いって...
-
別シートに罫線がひけない
-
Macアドレスを取得するには
-
RSSの表示速度に不満。
-
標準モジュールを削除したい。(...
-
VBA モジュールで共通に使う変...
-
ベースモジュールって?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel VBAでリンク切れをチェッ...
-
Excel VBAで、ユーザーフォーム...
-
ユーザー定義関数に#NAME?が返...
-
グラフのX,Y座標を取得したい
-
VBでグローバル変数を宣言するには
-
VBAで別モジュールへの変数の受...
-
VBAで旧字体を異字体に一括で変...
-
エクセルVBAでシートモジュール...
-
Excel VBA 『Call』で呼び出す...
-
vba userFormのSubを標準モジュ...
-
モジュールの最大数はいくつな...
-
ベースモジュールって?
-
【vba】フォームに書いてあ...
-
モジュールとクラスの違いって...
-
VBA This Workbookモジュール...
-
Form間の値の渡し方
-
SendKeysの使い方について
-
モジュールからフォームのボタ...
-
大量の標準モジュールを解放す...
-
標準モジュールを削除したい。(...
おすすめ情報