気になる話題

「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

伊勢谷友介の歴代彼女は?結婚してる?DVや大麻を吸うよう洗脳の話も

2020年9月8日に俳優の伊勢谷友介が大麻取締法違反の疑いで逮捕されました。 彼女に対してのDV疑惑などが言われていましたが、ついに大麻で逮捕! さらに「彼女を大麻を吸うよう洗脳」という話も! これが …

焼肉なべしま半額還元フェア

焼肉なべしまが2019年10月1日(火)~10月6日(日)まで半額還元フェア というのをやっています。内容は 「大感謝祭 半額還元フェア」お食事代金の半額相当を「ディナー券」として還元 ●期間/201 …

no image

iPhoneSE発表!価格とスペックは?iPhone8との違いは?買いなの?

以前から待たれていた2020年版新型「iPhoneSE」がやっと発表されました。 今までの情報通り「iPhone SE」ではなく「iPhone8」の後継機種といった内容ですね。 予約開始:4月17日2 …

no image

ワンパンマン183話でついにブラストが登場!神も登場?ONEとは違う展開に!

2021年1月25日にワンパンマンの183話が公開されました。 最近は、更新のパターンが一定ではなく突然更新されるような展開が続いていますが今回は2週間たたずに公開されました。 ただ、ONEの原作と違 …

no image

またPHPでGmailからSMTPでメールが送信できない!原因と対処方法は?

PHPからGmailを使ったメール送信についてですが、今まで正常に遅れていたものが、2022年6月から、突然送れなくなりました。 以前にも同じような現象があり、その時の対応として、使用するGmailア …