気になる話題

「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

十日恵比須(福岡)に行ってきた!混雑状況は?

本日1月10日の午前10時30分ごろに福岡の十日恵比須神社に参拝してきました。 1月10日の生大祭と言うことでひどい混雑状況ではないかと思いちょっと気合を入れて行きました。 ところが、実際行ってみると …

2020はバーチャルで!バーチャル渋谷ハロウィンフェスの参加方法や日程時間も調査!

最近の秋の最大のイベントと言ったらハロウィーンですね! 本当にここ数年は、特に渋谷のハロウィーンはすごい人出で盛り上ってます。 ただし、2020年は新型コロナウイルスの影響で3密を避ける目的の為に、渋 …

no image

「洋服の青山」就活用のリクルートスーツレンタルサービス!内容や使用方法・料金も調査!

「洋服の青山」が就活の学生ようにリクルートスーツのレンタルサービスを開始したそうです。 就職活動を行う学生にとってリクルートスーツは必需品ですが、就活以外に使用するわけでも無く買うのはもったいない感も …

no image

本家のワンパンマンが更新!フラッシュとソニックがパワーアップでガロウも再登場?

2020年10月6日、7日と連続で本家のワンパンマンが更新されていました。 現在132話です。 なんか閃光のフラッシュと音速のソニックが「あの御方」の秘伝書でパワーアップしているし、ネオヒーローズもな …

no image

PC版のGTA5が無料だったので入れてみた!

PC版のGTA V(Grand Theft Auto V)がEpic Gamesストアで、5月21日まで期間限定で無料で入手できます。 これについては、期間限定内限定で無料プレイできるというわけではな …