気になる話題

「VBA」このプロジェクトのコードは、64ビットシステムで使用するために更新する必要があります?対応方法は?

投稿日:

古いExcelで作られたVBAの内容に処理を追加して欲しいという依頼がありました。

VBAについては、ほとんど仕様も変わっていないので古くても問題ないだろうと思っていたところ

このプロジェクトのコードは、64ビットシステムで使用するために更新する必要があります。Declareステートメントの確認および更新を行い、次にDeclareステートメントに PtrSafe 属性を設定してください。

というメッセージが表示されVBAが動きません。

目次

「このプロジェクトのコードは、64ビットシステムで使用するために更新する必要があります」原因は?

このメッセージについて調べたところ、

「PtrSafe キーワードを含む Declare ステートメントが推奨される構文です。 64 ビットの数量を格納する必要がある Declare ステートメント (パラメーターと戻り値) のすべてのデータ型が更新され、ポインターとハンドルに LongLongまたは LongPtrを使用した後にのみ、32 ビットおよび 64 ビットプラットフォームの VBA バージョン 7 の開発環境で PtrSafe を含むステートメントが正しく動作します。 VBA バージョン 6 以前との下位互換性を確保するには、次の構造を使用します。」

というこでした。

つまり

「64ビットのVBA バージョン 7を使うときは、DeclareにはPtrSafeを付けろ」

ということらしいです。

なんのこっちゃ良くわからないのですが、PtrSafeを付ければ安全ですということなのか?

※Declareについては、簡単にいうと動的リンクライブラリ(DLL)をVBAなどから使うための宣言に使用します。

対応方法は?

実際の対応方法については簡単です。

こちらに記載されている内容に修正するだけで終わります。

Declare Sub → Declare PtrSafe Sub

Declare Function → Declare PtrSafe Function 

これだけで正常に動作するようです。

VBA バージョン 6 以前も使う場合は

#If VBA7 Then
Declare PtrSafe Sub…
#Else
Declare Sub…
#EndIf

で分ける必要がある問うことみたいですね。

まとめ

こんかいの件については、VBAでDeclareを使用することが、ほとんどなかったので全く知りませんでした。

ただ、これからも「昔作ったVBAのプログラムをそのまま使いたい」という要望はあると思います。

VBAの書き方自体はほとんど変わっていないのですが、たまにこういう仕様変更もあるので焦らずに対応したいですね。

 

 

-気になる話題

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

no image

「THE MUSIC DAY 2021」の出演者とタイムテーブルは?

2021年7月3日(土)に日本テレビ系音楽特番の「THE MUSIC DAY」が放送されます。 夏の音楽の祭典🎵『#THEMUSICDAY』8時間生放送決定❗&#xfe0 …

2020年10月1日は中秋の名月!各地で見れる時間と方角は?満月じゃないの?

2020年の「十五夜・中秋の名月」は10月1日です。 秋の夜のイベントといえば、やっぱり「十五夜でお月見」ですね。 今年は、関東から九州にかけて天気も良さそうできれいに見ることができそうです。 という …

no image

「a-nation online 2020」見逃し配信動画はdTVで!視聴方法は?無料で見れる?

8月29日に開催された総勢26組による「a-nation」史上初のオンラインフェス 「a-nation online 2020」 がdTVで配信されます! 計6時間にも及んだステージのうち、なんと4時 …

no image

上田桃子の結婚相手は元バスケ選手でお金持ち?出会いや馴れ初めを調査!

女子プロゴルファー上田桃子さんが、2021年6月15日(自身の35歳の誕生日)に結婚することが明らかになりました! 2021年6月15日は、天赦日と一粒万倍日が重なった最高の日ということです。 ところ …

no image

「Got To Eat」で【無限くら寿司】!やり方は?

Go To Eatキャンペーンで「鳥貴族」を使った「トリキの錬金術」が問題になっていましたが、今度は無限に寿司が食べられる「無限くら寿司」が話題になっています。 回転寿司チェーンの「くら寿司」は、10 …