

下記マクロは、列を指定してサブプロシージャColumnTreatへ引数として渡し、処理するものです。処理内容は質問と関係ありません。起動したところ 、★位置で「ユーザ定義型は定義されてません」Columnはオブジェクトではないのですか?そういえば今まで見たことない??と思い質問しました。この形式は出来ないのですか?
Sub test()
Call CleanUp(colmns("A"))
End Sub
Sub ColumnTreat(ByRef Tcol As Column) ’★
Dim c As Range
With Tcol
For Each c In Range(.Cells(1), .Cells(Rows.Count).End(xlUp))
c.Value = 1 'セルごとの処理
Loop
End With
End Sub
列指定をLong (1)あるいはString ("A")で渡す方法もありますが、Worksheetを別途指定する必要があるので、出来れば避けたいです。何かいい方法はないでしょうか?
No.1ベストアンサー
- 回答日時:
こんにちは。
Column というのは、Range オブジェクトのプロパティですね。
データ型は、Long型です。
一応、コードのミスを訂正しておきます。
'//
Call CleanUp(colmns("A"))
↓
Call ColumnTreat(Columns("A")) '質問内容から、変更します。ただし、ここは、もうひとつ工夫が必要かもしれません。
''Range型で渡そうが、数値型で渡そうが、文字型で渡そうが、間違いがなければ、結果オーライだと思います。
''しかし、状況にも依存しますが、Rangeの変数(例:Rng) で渡すのが、ベターだと思います。Columns("A")のような、リテラルな方法ではなく、初心者の人がなにげに無茶する方法で、Sheet を含めたRange型変数が、実は、そこには結構テクニックがあって、何かと簡単にさせてくれます。悪い方法は、文字型のアドレスです。再度、Rangeを指定しなければならないから二度手間です。
'//
Sub ColumnTreat(ByRef Tcol As Column) ’★
↓
Sub ColumnTreat(ByRef Tcol As Range)
'//
For Each c In Range(.Cells(1), .Cells(Rows.Count).End(xlUp))
c.Value = 1 'セルごとの処理
Loop
↓
For Each c In Range(.Cells(1), .Cells(Rows.Count).End(xlUp))
c.Value = 1 'セルごとの処理
Next c 'Loop ではなく、Next
'//
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 前回ご教授いただいたコードに覚えたてのループ処理で品名りんごAから順に20回for nextでループ 7 2023/01/13 22:01
- Visual Basic(VBA) フォルダの場所を可変にしたいです(マクロ) 4 2023/05/11 10:00
- Visual Basic(VBA) Excelで下記のようにマクロを作ったところ、一回目は実行できたのですが、二回目以降「実行時エラー1 1 2022/03/25 08:08
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
- Visual Basic(VBA) VBAで質問ですが、皆さんはどの様に導き出しているのでしょうか? 6 2022/05/03 21:53
- Excel(エクセル) B列に文字がはいったらA列に数字が入るマクロードを完成させたい 4 2023/04/21 01:58
- Visual Basic(VBA) Sheet3から2つの条件でオートフィルターで抽出した個数をSheet2へ入力するマクロで、一つ目の 4 2023/01/12 23:40
- Visual Basic(VBA) 複数csvを横に追加していくマクロについて 2 2023/04/25 09:19
- Visual Basic(VBA) まとめシートから集計シートへA列のコードが一致したら1行コピーするマクロをネット上で見つけました。こ 1 2022/08/30 14:11
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
マクロの解読に困っています
-
エクセルVBA作成時と実行時のエ...
-
複数の関数の中から戻り値の戻し方
-
Excel VBA セルの名前があるか...
-
VBSのプログラムをタスクスケジ...
-
AVIFileInitに関して
-
VBS mdb参照時にテーブルor列が...
-
VBA Vlookup #N/A表示させない方法
-
vbaのエラー対応(実行時エラー...
-
『Do ~ Until (0)』の『Until ...
-
SQLの条件式
-
「内部処理形式 String の Vari...
-
IF文に時間(何時から何時ま...
-
MS Access と VB6
-
ExcelのVBAで、選択したファイ...
-
特定の名前のオートシェイプの...
-
UWSファイルを VBで実行させたい
-
特定のファイルを他のプロセス...
-
処理水問題についてスライドを...
-
ListViewから選択中の文字列を取得
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【C#/Java?】try-catchでcatch...
-
vbaのエラー対応(実行時エラー...
-
private subモジュールを他のモ...
-
マクロで、次のコードへ行く前...
-
シグナル 6(SIGABRT)とは?
-
特定の名前のオートシェイプの...
-
IF文に時間(何時から何時ま...
-
どう増強すべきか
-
特定のファイルを他のプロセス...
-
Word VBA。各マクロの間に待ち...
-
どうやってもFor文を抜けてしま...
-
Excel VBA セルの名前があるか...
-
ExcelのVBAで、選択したファイ...
-
【C#】Page_Loadさせない方法に...
-
StatusStripの表示が更新されな...
-
途中で処理を中断させたい (ア...
-
エクセル VBAで複数セル選択時...
-
Functionで戻り値を複数返す方法
-
VBAでBook読み込み時の非表示方...
-
VBA 複数の行を高速で削除する...
おすすめ情報