ByRef引数の型が一致しません。
ツイッターで出題したVBAに関する問題です。
ただし今回は、出題というより勝手に連続ツイートで出題と解説をしたツイートの保存記録になります。
出題ツイート
https://twitter.com/yamaoka_ss/status/1704787902432264666
ふふふ、難しそうな言い方をすれば誤魔化せると思っているんだろ・・・
![VBA マクロ ByRef引数の型が一致しません](image2100.jpg)
このエラー見た時、30秒くらい固まりましたwww
これはFunctionを呼んでいる箇所で発生しています。
添付画像は簡略化して再現させたものです。
さて、引数に何を指定したのでしょうか?
【VBAなぞなぞ】
![VBA マクロ ByRef引数の型が一致しません](image315.jpg)
![VBA マクロ ByRef引数の型が一致しません](image2100.jpg)
これはFunctionを呼んでいる箇所で発生しています。
添付画像は簡略化して再現させたものです。
さて、引数に何を指定したのでしょうか?
【VBAなぞなぞ】
![VBA マクロ ByRef引数の型が一致しません](image315.jpg)
解答ツイート
このメッセージはあまり見ないですよね。
簡単に出すなら、
fnc1(Sheet1)
fnc1(ThisWorkbook)
こういう指定になります。
似ているけど、
fnc1(Worksheets(1))
これじゃダメなんですよね、違うメッセージになります。
このメッセージなら良く見かけると思います。
![VBA マクロ ByRef引数の型が一致しません](image410.jpg)
fnc1(Sheet1)
fnc1(Worksheets(1))
これでなぜ違うメッセージになるかというと・・・
説明が難しくなりそうですし、私も上手く説明できない・・・
要はデフォルトのプロパティが起動されるかどうかの違いと考えれば良いですね。
Sheet1
これはプロバティが起動されずにオブジェクトが渡される。
ByrefのStringにオブジェクトを渡そうとしているので、
「ByRefの引数の型が一致しません」になります。
対して、
Worksheets(1)
これは型がObjectなので引数で指定した時にデフォルトプロパティを呼び出そうとしています。
なのでメッセージも「…プロパティまたはメソッドをサポートしていません。」
あー、Objectなのでという書き方は良くなかったかもしれません。
As Object
とは違いますね。
As Objectの変数なら引数の型が一致しませんになるので。
添付の場合は、Asの型が何でも引数の型がになりますね。
ふむ、ここで説明に困った・・・ようわからん・・・
![VBA マクロ ByRef引数の型が一致しません](image510.jpg)
オブジェクトの話は止めよう、難しすぎるのでwww
私が実際にやったのは、添付になります。
普通はこういう事しないですよね。ちょっと横着したのですが…
メッセージを読んでしばらく固まりましたw
直し方としては、
ByVal にするか、CStr(ary(0))またはary(0)&""とかで良いですかね。
![VBA マクロ ByRef引数の型が一致しません](image610.jpg)
ということで、VBAってちょっと変な書き方すると訳わからないエラーメッセージが出て、それで嫌いになる人がいるかもしれないと思いました。
初心者向けの基本的な書き方に従って書けばこういう事にはならないのですけど…
分からなかったら、Xツイッターで、#助けてVBA でポストしてみてください。
簡単に出すなら、
fnc1(Sheet1)
fnc1(ThisWorkbook)
こういう指定になります。
似ているけど、
fnc1(Worksheets(1))
これじゃダメなんですよね、違うメッセージになります。
このメッセージなら良く見かけると思います。
![VBA マクロ ByRef引数の型が一致しません](image410.jpg)
fnc1(Worksheets(1))
これでなぜ違うメッセージになるかというと・・・
説明が難しくなりそうですし、私も上手く説明できない・・・
要はデフォルトのプロパティが起動されるかどうかの違いと考えれば良いですね。
Sheet1
これはプロバティが起動されずにオブジェクトが渡される。
「ByRefの引数の型が一致しません」になります。
対して、
Worksheets(1)
これは型がObjectなので引数で指定した時にデフォルトプロパティを呼び出そうとしています。
なのでメッセージも「…プロパティまたはメソッドをサポートしていません。」
As Object
とは違いますね。
As Objectの変数なら引数の型が一致しませんになるので。
添付の場合は、Asの型が何でも引数の型がになりますね。
ふむ、ここで説明に困った・・・ようわからん・・・
![VBA マクロ ByRef引数の型が一致しません](image510.jpg)
私が実際にやったのは、添付になります。
普通はこういう事しないですよね。ちょっと横着したのですが…
メッセージを読んでしばらく固まりましたw
直し方としては、
ByVal にするか、CStr(ary(0))またはary(0)&""とかで良いですかね。
![VBA マクロ ByRef引数の型が一致しません](image610.jpg)
初心者向けの基本的な書き方に従って書けばこういう事にはならないのですけど…
分からなかったら、Xツイッターで、#助けてVBA でポストしてみてください。
同じテーマ「ツイッター出題回答 」の記事
ツイッターで出したエクセルの問題です。誤字脱字は気を付けてもなかなか… 今回はエクセル関数で意図的に脱字を作ろうという問題です。関数は組み合わせかた次第です。出題ツイート 出題ツイートへのリンク 【エクセル問題】※関数は組み合わせだ編 脱字メーカー A列の文字列から1字消した全パターンを出力して下ください。
リーグ表に対戦番号を振るツイッターで出したエクセルの問題です。総当たりリーグ戦の表に試合番号を振る問題です。出題の主旨としては、これをスピル一発でやってみましょうと言うものです。出題ツイート ツイートが不調?で2回同じツイートをしました。
数列内の連続偶数のみ順序を入れ替えるツイッターで出題したエクセル数式問題です。数列があり、その中の偶数の連続部分だけを順番を入れ替えるという問題です。元は他のアカウントで出された問題なのですが、改めて私から出だししたものになります。出題ツイート 一応数式が作れたので出題します。
ランクによりボイントを付ける(同順位はポイントを分割)ツイッターで出題したエクセル数式問題です。点数一覧の順位に応じたポイントを付けます。同順位がある場合は、同順位でポイントを分割します。出題ツイート 【エクセル問題】 A列の点数の順位に応じたポイントをB列に付けます。
記号を繰り返してグラフ作成(10単位で折り返す)ツイッターで出題したエクセル数式問題です。記号を繰り返してグラフにする数式の紹介は良く見かけます。それでは、記号を10個単位で折り返してグラフ化する数式を作成してください。出題ツイート 【エクセル問題】 記号を繰り返してグラフにするのは良くありますよね。
Excel関数の引数を省略した場合についてツイッターで出題したエクセル数式問題です。引数を省略した時の挙動についての問題です。問題の回答選択肢が間違っていたりして申し訳ありません。引数の省略については説明することも少ないので、記録として残しておくことにしました。
シートコピー後のアクティブシートは何かツイッターで出題したVBAに関する選択問題です。シートコピーした後に、変数にActiveSheetを入れます。その変数に入っるシートは何かと言う問題です。つまり、シートコピー直後のActiveSheetは何か? と言う問題です。
ByRef引数の型が一致しません。シートのActiveXチェックボックスの指定方法
ツイッターで出題したVBAに関する問題です。シートに挿入した、ActiveXのチェックボックスを標準モジュールから指定する場合のVBAの書き方を問う問題です。出題ツイート https://twitter.com/yamaoka_ss/status/1705130181965598906 【VBA問題】 シート(オブ…
列全体を指定する時のRangeとColumnsの違いツイッターで出題したVBAに関する問題です。列全体を指定する書き方に、Range Columns この2通りがあります。そこで、この2通りの書き方の違いは何かを問う選択問題です。出題ツイート https://twitter.com/yamaoka_ss/status/1705178543683174475 【VBA…
スピルのゴーストの範囲を選択するVBAツイッターで出題したVBAに関する問題です。スピルは.2019年に実装された新機能です。数式を入力したセルから結果があふれて隣接したセルにも出力されるのがスピルです。スピルについての詳細は以下を参照してください。
新着記事NEW ・・・新着記事一覧を見る
正規表現関数(REGEXTEST,REGEXREPLACE,REGEXEXTRACT)|エクセル入門(2024-07-02)
エクセルが起動しない、Excelが立ち上がらない|エクセル雑感(2024-04-11)
ブール型(Boolean)のis変数・フラグについて|VBA技術解説(2024-04-05)
テキストの内容によって図形を削除する|VBA技術解説(2024-04-02)
ExcelマクロVBA入門目次|エクセルの神髄(2024-03-20)
VBA10大躓きポイント(初心者が躓きやすいポイント)|VBA技術解説(2024-03-05)
テンキーのスクリーンキーボード作成|ユーザーフォーム入門(2024-02-26)
無効な前方参照か、コンパイルされていない種類への参照です。|エクセル雑感(2024-02-17)
初級脱出10問パック|VBA練習問題(2024-01-24)
累計を求める数式あれこれ|エクセル関数応用(2024-01-22)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.RangeとCellsの使い方|VBA入門
6.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
7.メッセージボックス(MsgBox関数)|VBA入門
8.セルのクリア(Clear,ClearContents)|VBA入門
9.並べ替え(Sort)|VBA入門
10.ブック・シートの選択(Select,Activate)|VBA入門
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。