

下記マクロは、列を指定してサブプロシージャ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で質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【C#/Java?】try-catchでcatch...
-
private subモジュールを他のモ...
-
シグナル 6(SIGABRT)とは?
-
Excel VBA セルの名前があるか...
-
IF文に時間(何時から何時ま...
-
マクロで、次のコードへ行く前...
-
VB6にてネットワーク上にある共...
-
Word VBA。各マクロの間に待ち...
-
VBA 複数の行を高速で削除する...
-
【VBA】エラー処理で別プロシー...
-
ListViewから選択中の文字列を取得
-
Vba 互換モードでのAppActiveに...
-
ExcelのVBAで、選択したファイ...
-
入力した値が不正というよりイ...
-
途中で処理を中断させたい (ア...
-
複数のファイルに対し同じ処理...
-
シェルスクリプトでファイル内...
-
n88 Basic に関して(ループ)
-
条件文でelseはつけるべき?
-
バッチファイルでのエラー処理...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【C#/Java?】try-catchでcatch...
-
private subモジュールを他のモ...
-
vbaのエラー対応(実行時エラー...
-
シグナル 6(SIGABRT)とは?
-
IF文に時間(何時から何時ま...
-
マクロで、次のコードへ行く前...
-
Excel VBA セルの名前があるか...
-
どう増強すべきか
-
特定の名前のオートシェイプの...
-
途中で処理を中断させたい (ア...
-
特定のファイルを他のプロセス...
-
順番に処理させたい
-
Word VBA。各マクロの間に待ち...
-
StatusStripの表示が更新されな...
-
ドリブン??
-
ExcelのVBAで、選択したファイ...
-
RaiseEventのメリット
-
【VBA】エラー処理で別プロシー...
-
エクセルVBAでロックをかけたい
-
どうやってもFor文を抜けてしま...
おすすめ情報