質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.45%

  • C

    4690questions

    C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

  • C++

    4553questions

    C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

  • Windows

    1739questions

    Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

Excel がインストールされているかどうか調べる方法

解決済

回答 3

投稿

  • 評価
  • クリップ 0
  • VIEW 2,915

BeatStar

score 1380

前提・実現したいこと

C/C++ ( Windows API あり ) で Excel がインストールされているかどうかを調べたい

あるソフトがインストールされているかどうかを調べる方法ってありませんか?

Excelがインストールされているかどうかを調べる -> true のとき バージョン をチェック -> C++で作成したプログラムからExcel操作...

です。

調べてみると

「レジストリを読み込んで書き込まれていればインストールされている」

といった感じのものがあった気がします。

なので、

コマンドプロンプトからレジストリの検索 ( コマンド忘れましたが... ) を一度やってみて、
Excel関係のものをチェックしてみましたが、複数ありどれがどれか...

また、レジストリの操作用の関数もちんぷんかんぷん...
( 定数はどれを使えばいいのやら... またキーの階層?もよくわからない... )

普通のINIファイルとかテキストファイルとかなら復元可能ですが、
レジストリは誤って書き換えてしまうと厄介なので試そうにも...
( バックアップとればいいかもしれませんが、レジストリ関連は初めて使うため、使い慣れてないので。 )

それともレジストリを読み込まずに、インストールされているかどうかをプログラムから調べる
方法ってあるのでしょうか?

ソースコードっていうより、

たとえば、(例はわかっていないので適当ですが。)


  1. まず RegOpenKeyEx関数でレジストリを開く。
    第一引数:どれでもいい
    第二引数: ファイル名
    第三引数: KEY_ALL_ACCESS
    第四引数: 戻り値用 HKEY

  2. RegQueryValueEx関数で読み込む。
    第二引数: "VERSION"

...


といった具合になるべく細かく説明していただけたら嬉しいです。

( あまりにも情報が少ないので できませんが、そういう情報さえあればなんとかできると
思います。 )

これは追加 ( オプション。なくてもいいです。 ) ですが、
Excelだけでなく、他のソフトのインストールもチェックする方法も知りたいです。
( 上記のレジストリの説明の 1の 第三引数を KEY_*** に書き換えるとか。 )

[環境等]:
言語: C/C++ ( Windows API 実装あり )
コンパイラ: g++

宜しくお願い致します。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

checkベストアンサー

0

こんにちは。

オートメーション(COM)を使うとExcelをコントロールできます。
が、ネイティブのC++から行うのは鬼のように手間がかかります。
ちょっと古いですが、下記資料がありました。
MFC または #import を使用せずに C++ から Excel を自動化する方法
泣きたくなるほど面倒です。

私は使ったことないのですが、#importを使うとそこそこ楽できるようです。(MFCはMFC自体のハードルが結構高いと思います。)
C++で、エクセルにデータを追加。
これはExcelのバージョンを指定する必要がありますが、下記のようなテクニックもあるそうです。
エクセルのバージョンに依存しないimport

しかし、.NETからなら拍子抜けする程簡単です。
Excelファイルにアクセスするには?[C#、VB]
恐らく、VC++は諦めて、C#で制御することが現実的だろうと思います。

もし、C++でどうしても行いたい場合、有償ですがC++Builderというコンパイラなら.NET程度の手間で可能です。(Starterなら個人でも買えないことはないと思いますが、32bit版しか開発できないようです。)
C++BuilderからOLEでExcelを制御しファイルを読む


なお、レジストリをアクセスしてExcelの有無を確認するだけなら、ネイティブのVC++でも、もう少し手間なくできると思いますが、

また、レジストリの操作用の関数もちんぷんかんぷん... 
( 定数はどれを使えばいいのやら... またキーの階層?もよくわからない... )

このような状態でしたら、開発用のコンピュータにインストールしているWindowsを破壊するのが落ちですのでお薦めしません。レジストリ操作について詳しくご自身で調査でき、どうしても判らない部分のみを質問できる程度のスキルがないと厳しいと思います。
ここでソースを貰ったとして、そのソースがバグっていたらどうします?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/05/12 18:04

    ご回答ありがとうございます。
    COMか.NET ですね。
    COMの方のやり方も調べてはいたのですが、
    そこまで ( COMで取得して 取得できれば インストール済み とみなす方法 ) は思いつきませんでした。

    キャンセル

0

やり方はわからないのですが(すみません)、レジストリを直接見るのではなく、COMなどでアプリケーションに接続できればインストールされている、接続できなければインストールされていない、という見方の方がいいのかなと思いました。
一般的にどうなのかはわかりませんが。
COMとかOLE(古い?)とかDDE(古い?)とかActiveXとか。どれがいいのかわかりませんが…。
参考まで。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

ttyp03様の回答されている方法に私も賛成します。

インストールの確認と、その後に操作等の制御まで行うとなると、製品が備えている外部インターフェイスを介してのアクセスが必須となるでしょう。Excel を含む Office 製品は OLE/COM/ActiveX などのインターフェイスを昔から備えていますので、単純に直接つなげてみて判定するのが製品の細かいバージョンにもあまり依存せずに判断できる無難な方法と考えます。

確認のための具体的な方法については、C++ からだと GetActiveObject API で Excel オブジェクトの取得ができるかどうかで判断するのが手です。以下、具体的なコードもあるため参考になるでしょう。
Visual C++ を使用した Office オートメーション

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.45%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • C

    4690questions

    C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

  • C++

    4553questions

    C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

  • Windows

    1739questions

    Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。