
いつもお世話になっております。
今更な話なのですが、
SubプロシージャなどをCallで呼び出す意味は何なのでしょうか?
例)
ユーザーフォーム:UserForm1
Public Sub CommandButton1_Click()
Call DATA_CREATE
End Sub
Sub DATA_CREATE()
Range("A1").value=1
Range("A2").value=5
End Sub
----------------------------
ためしに書いてみましたが(実際に実行していません
Subと書いてあるものはCallを使わなくても
上手く動作します。
Public Sub CommandButton1_Click()
DATA_CREATE
End Sub
上記方法でも大丈夫です。
何か意味などありましたら、教えてくださるとうれしいです!
よろしくお願い致します。
No.3ベストアンサー
- 回答日時:
こんにちは!
すでに回答は出ていますが、
経験上で・・・
複数Sheetを操作したい場合、シートモジュールでは別Sheetを操作できないコトがあります。
しかし、標準モジュールでは可能です。
Changeイベントなどはシートモジュールになりますので
シートモジュールで動かないコードを標準モジュールに記載しておけば
「Call」で呼び出し、別Sheetの操作も可能になることがあります。
そのような場合に「Call」を使ったりします。m(_ _)m
回答ありがとうございました!
シートモジュールを使う場合に良くCallを使うのですね!
うーん、奥が深いです・・・
回答ありがとうございました。
No.2
- 回答日時:
省略可なので、別に書かなくていいんですが、他の言語でも
「サブルーチン」を呼び出すときは「Call」を使うことが多いので、
後で見て分かりやすくするために、あえてつけている人も多い
と思いますよ。
サブルーチン名だけ書いていると、一瞬何をやってるのかわから
なくなりますから・・・。
回答ありがとうございました!
他の言語だと、Call必須だったりしますよね~
色んな言語が混ざって頭がパンクしそうです(笑
回答ありがとうございました。
No.1
- 回答日時:
>何か意味などありましたら
Callステートメントのヘルプをちょっと開いて見てみると
----------------
解説
プロシージャを呼び出すとき、キーワード Call は省略できます。(以下略)
----------------
と書いてある通り、callを省略してプロシジャ名だけ書いてもcallで実行されてるだけです。
「何か意味」という事で言えば、可読性や、社内などでマクロの書き方ルールを定めている場合にそれに準拠するといった意味があります。
回答ありがとうございました!
callが在っても無くてもあまり変わらないとのことですかね。
callが在ったほうが、このプロシージャに飛んでる!とパッと見て分かるので、これからも書いていこうと思います。
回答ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 標準モジュール Public mOnTime As Date Sub sample() '実行プロシ 1 2023/02/22 15:44
- Excel(エクセル) エクセルVBAでオブジェクトが必要です 2 2022/09/10 16:37
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2022/05/26 17:19
- Visual Basic(VBA) 前回ご教授いただいたコードに覚えたてのループ処理で品名りんごAから順に20回for nextでループ 7 2023/01/13 22:01
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Visual Basic(VBA) データベースから絞り込んでデータを読み込み 1 2023/02/21 19:51
- Visual Basic(VBA) Excelで下記のようにマクロを作ったところ、一回目は実行できたのですが、二回目以降「実行時エラー1 1 2022/03/25 08:08
- Visual Basic(VBA) 【Excel VBA】自動メール送信の機能追加 5 2022/09/29 12:53
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 1 2023/08/10 14:24
- Excel(エクセル) 【マクロ】スクショ印刷がうまく動かない件 5 2022/12/06 17:37
このQ&Aを見た人はこんなQ&Aも見ています
-
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
VBAでfunctionを利用しようとしたときに「引数は省略できません」というエラーが出ます
Visual Basic(VBA)
-
VB6 開発環境のエディタに行番号を表示
Visual Basic(VBA)
-
-
4
CSVファイルの中で、「 , 」カンマを使いたい
その他(コンピューター・テクノロジー)
-
5
VBA エンターキーでイベントに入りたい。
PowerPoint(パワーポイント)
-
6
VBA 数式を残して値をクリアについて
Excel(エクセル)
-
7
VBAのプログラムで、DIAG = 1# / A(L, L) や R(
その他(プログラミング・Web制作)
-
8
バッチ処理でファイルの中身を変数に入れるやり方
その他(プログラミング・Web制作)
-
9
全ての変数を一気にリセットする方法はありますか?
PowerPoint(パワーポイント)
-
10
Application.ScreenUpdating = Falseが効きません
Visual Basic(VBA)
-
11
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
12
VBAでの Replace関数で、ワイルドカードは使えないのでしょうか?
Visual Basic(VBA)
-
13
Access コンボボックスの値をクリアしたい。
PowerPoint(パワーポイント)
-
14
Access VBAで行ラベルが定義されていないというエラーが出ます
Access(アクセス)
-
15
Excelでセル参照したとき、書式も一緒に持ってくるには?
Windows Vista・XP
-
16
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
17
FORMが開いているかどうかの確認方法
Visual Basic(VBA)
-
18
Accessデータベースの最適化をExcelVBAでやりたい
その他(データベース)
-
19
FriendとPublicの違い。。。
Visual Basic(VBA)
-
20
VBA シートのボタン名を変更したい
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルVBAでシートモジュール...
-
Excel VBAで、ユーザーフォーム...
-
Excel VBAでリンク切れをチェッ...
-
ユーザー定義関数に#NAME?が返...
-
Excel VBA 定義されたプロージ...
-
vba 標準モジュールインポート...
-
perlを使って音(sound.wav)を...
-
モジュールからフォームのボタ...
-
Sub Workbook_Open()でユーザー...
-
Tomcat マイナーバージョン移行...
-
関数の引数にクラスを使いたい
-
非常に恥ずかしいレベルの質問...
-
ExcelVBA:パブリック オブジェ...
-
Data::Dumperモジュールについて
-
クラスモジュールについて
-
VBA This Workbookモジュール...
-
strict.pmはどこにありますか?
-
EXECEL VBA コマンドボタンか...
-
VBAで旧字体を異字体に一括で変...
-
A88M-G/3.1(ASRock)のマザボに...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel VBAでリンク切れをチェッ...
-
Excel VBAで、ユーザーフォーム...
-
ユーザー定義関数に#NAME?が返...
-
vba userFormのSubを標準モジュ...
-
Excel VBA 定義されたプロージ...
-
モジュールとクラスの違いって...
-
モジュールの最大数はいくつな...
-
VBAで別モジュールへの変数の受...
-
Excel VBA 『Call』で呼び出す...
-
エクセルVBAでシートモジュール...
-
VBでグローバル変数を宣言するには
-
【vba】フォームに書いてあ...
-
SendKeysの使い方について
-
モジュールからフォームのボタ...
-
VBAで旧字体を異字体に一括で変...
-
モジュールとは何ですか
-
ExcelでTelnetを動かしたい
-
標準モジュールを削除したい。(...
-
VBA This Workbookモジュール...
-
Access VBA標準モジュールにつ...
おすすめ情報