C# と VB.NET の質問掲示板
ASP.NET、C++/CLI、Java 何でもどうぞ
掲示板トップ
C# と VB.NET 入門
新規作成
利用方法
ツリー表示
トピック表示
ランキング
記事検索
過去ログ
ログ内検索
キーワードを複数指定する場合は 半角スペース で区切ってください。
検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
[返信]をクリックすると返信ページへ移動します。
キーワード
/
検索条件
/
(AND)
(OR)
検索範囲
/
(現在のログ)
(全過去ログ)
(過去ログ1)
(過去ログ2)
(過去ログ3)
(過去ログ4)
(過去ログ5)
(過去ログ6)
(過去ログ7)
(過去ログ8)
(過去ログ9)
(過去ログ10)
(過去ログ11)
(過去ログ12)
(過去ログ13)
(過去ログ14)
(過去ログ15)
(過去ログ16)
(過去ログ17)
(過去ログ18)
(過去ログ19)
(過去ログ20)
(過去ログ21)
(過去ログ22)
(過去ログ23)
(過去ログ24)
(過去ログ25)
(過去ログ26)
(過去ログ27)
(過去ログ28)
(過去ログ29)
(過去ログ30)
(過去ログ31)
(過去ログ32)
(過去ログ33)
(過去ログ34)
(過去ログ35)
(過去ログ36)
(過去ログ37)
(過去ログ38)
(過去ログ39)
(過去ログ40)
(過去ログ41)
(過去ログ42)
(過去ログ43)
(過去ログ44)
(過去ログ45)
(過去ログ46)
(過去ログ47)
(過去ログ48)
(過去ログ49)
(過去ログ50)
(過去ログ51)
(過去ログ52)
(過去ログ53)
(過去ログ54)
(過去ログ55)
(過去ログ56)
(過去ログ57)
(過去ログ58)
(過去ログ59)
(過去ログ60)
(過去ログ61)
(過去ログ62)
(過去ログ63)
(過去ログ64)
(過去ログ65)
(過去ログ66)
(過去ログ67)
(過去ログ68)
(過去ログ69)
(過去ログ70)
(過去ログ71)
(過去ログ72)
(過去ログ73)
(過去ログ74)
(過去ログ75)
(過去ログ76)
(過去ログ77)
(過去ログ78)
(過去ログ79)
(過去ログ80)
(過去ログ81)
(過去ログ82)
(過去ログ83)
(過去ログ84)
(過去ログ85)
(過去ログ86)
(過去ログ87)
(過去ログ88)
(過去ログ89)
(過去ログ90)
(過去ログ91)
(過去ログ92)
(過去ログ93)
(過去ログ94)
(過去ログ95)
(過去ログ96)
(過去ログ97)
(過去ログ98)
(過去ログ99)
(過去ログ100)
(過去ログ101)
(過去ログ102)
(過去ログ103)
(過去ログ104)
(過去ログ105)
(過去ログ106)
(過去ログ107)
(過去ログ108)
(過去ログ109)
(過去ログ110)
(過去ログ111)
(過去ログ112)
(過去ログ113)
(過去ログ114)
(過去ログ115)
(過去ログ116)
(過去ログ117)
(過去ログ118)
(過去ログ119)
(過去ログ120)
(過去ログ121)
(過去ログ122)
(過去ログ123)
(過去ログ124)
(過去ログ125)
(過去ログ126)
(過去ログ127)
(過去ログ128)
(過去ログ129)
(過去ログ130)
(過去ログ131)
(過去ログ132)
(過去ログ133)
(過去ログ134)
(過去ログ135)
(過去ログ136)
(過去ログ137)
(過去ログ138)
(過去ログ139)
(過去ログ140)
(過去ログ141)
(過去ログ142)
(過去ログ143)
(過去ログ144)
(過去ログ145)
(過去ログ146)
(過去ログ147)
(過去ログ148)
(過去ログ149)
(過去ログ150)
(過去ログ151)
(過去ログ152)
(過去ログ153)
(過去ログ154)
(過去ログ155)
(過去ログ156)
(過去ログ157)
(過去ログ158)
(過去ログ159)
(過去ログ160)
(過去ログ161)
(過去ログ162)
(過去ログ163)
(過去ログ164)
(過去ログ165)
(過去ログ166)
(過去ログ167)
(過去ログ168)
(過去ログ169)
(過去ログ170)
(過去ログ171)
(過去ログ172)
(過去ログ173)
(過去ログ174)
(過去ログ175)
(過去ログ176)
(過去ログ177)
(過去ログ178)
(過去ログ179)
強調表示
/
ON
(自動リンクOFF)
結果表示件数
/
20件
30件
40件
50件
100件
記事No検索
/
ON
大文字と小文字を区別する
No.7066 の関連記事表示
ヒット / 2件
(1-2 を表示)
<<
0
>>
■7066
Re[4]: Excelのバージョンの違いをカプセル化する方法について
□投稿者/ NZ-000 -
(2006/10/02(Mon) 16:02:28)
分類:[C#]
皆さん貴重なご意見ありがとうございます。
>渋木宏明(ひどり)さん
>Excel.Application.Version を参照するのが無難です。
>.dll や .exe が存在していても、それが本当アプリケーション実行に使用されているものかを検査するのは困難です。
>プロパティ値の取得くらいなら、C# でレイトバインドでオートメーションしても大した手間にはなりません。
遅延バインドについて以下を参照していて思ったことがあります。
http://support.microsoft.com/default.aspx?scid=kb;JA;302902
"遅延バインディングを使用するオートメーション クライアントの作成"
の項で以下のようにしてインスタンスを取得しています。
object objApp_Late;
Type objClassType;
objClassType = Type.GetTypeFromProgID("Excel.Application");
objApp_Late = Activator.CreateInstance(objClassType);
確かにこのソースを見る限りバージョンに依存したコードが消えているように思えます。
しかし、Versionプロパティを参照するためにはオブジェクト型のobjApp_Lateを
Excel.Applicationインスタンスにキャストしなければいけないと思います。
そして、その際どちらの(2000or2003)Excel.Applicationクラスを使うか考えることになるかと思います。
これを考えた時点でExcelのバージョンに依存してしまう気がしますがどうなんでしょうか。
例えば、それを2003のExcel.Applicationクラスを使って組んでおいて、2000しかインストールされていない環境で実行すると2003のCOMライブラリがありませんというエラーは出ないでしょうか?
(事前バインディングの場合はでました。当然ですが)
というより参照設定せずにそのクラスが使えるのかが不思議でならないのですが、あいにくまだコード上で試せていません。
>名前空間は IDE が「参照設定」を行う際に勝手につけたものです。
>手動で tlbimp すれば自分で好きなように付け替えられます。
参考になります。ただ以下に関して上記のこともあって、はたして全てを遅延バインディングで解決できるのか疑問に思っているため共通化部分が見えてきません。
>メソッド名やプロパティ名に関しては「追加」や「拡張」はあると思いますが、「共通化できる部分が何一つ無い」ような状況ではないように見えます。
Excelのバージョンによってインターフェースが異なる名前空間に個別に定義されています。Excelのアプリケーション変数を共通化することもできません。私はインストールされているExcelを判別した後は、それぞれのバージョンにあわせた独自のコードを書くしか道はないのではと思っていました。
まだちょっと先が見えていません。
>> 4.2000と2003が共存している環境で、バージョン指定でExcelを開く方法
>> 共存環境を作成し、例えば、2000のCOMライブラリを用いてExcelを起動しようとしたにもかかわらず、
>> 起動するExcelは2003の方です。予想では2000が起動するのかと思っていたので疑問に思っています。
>> ちなみにインストールは最初に2000、次に2003の順に行いました。
>> 何か方法があれば教えてください。
>どうしたいんですか?
>上位バージョンが起動する分には問題ないように思えますが。
前提としてプログラム内で勝手にExcelファイルのバージョンを書き換えたくないという思いがあります(いいわすれていましたが今回考えているのはExcelファイルのリードオンリーです)。
2000のみインストールしているユーザーと2003のみインストールしている間で一つのExcelファイルのバージョンが、このソフトを使うたびにころころ変わることになります。上書きした際にどの程度のデータが欠落するか定かでない(勉強不足)のため、できる限り書き換えたくないのです。
しかも現状では、例えば、2000で作られたExcelファイルを2003で開き閉じようとすると、何も変更を加えていないにも関わらず、バージョンの不一致から変更を保存するか聞いてくるダイアログがExcel側で自動でたちが上がります。これが出るとプログラム側でアプリケーションを閉じることがでません(プロセスをKillすればいける?)。
事前にExcelファイルのバージョンを調べる手段もわかっていないため、Excel.Application.Save()で無理やり上書きするしかありません。従って「このソフトでExcelファイルを使うとデータが欠落する可能性がありまっせ」という極めて迷惑なソフトに仕上がっています。
>まどかさん
>インストールバージョンについては、
>HEKY_CLASSES_ROOTを見るとExcel.Application.バージョン番号となっているようですので
>それを取得する方法があります。
なるほど、確かにありますね。2000と2003を共存させている環境で見ると、以下のようなキーがありました。
Excel.Application (←不明)
Excel.Application.11 (Excel2003)
Excel.Application.9 (Excel2000)
参考にさせてもらいます。
>そこのCLSIDからたどっていけばインストールパスがわかりますので
わかりました。
>GetObject(VB関数)で指定したバージョンのインスタンスを作れそうです。
ちょっとまだ調べきれていません。
>中博俊さん
>XP の PIAと、2003のPIAでは名前空間から違うのでそれの事を言っているのだと思われます。
XPと2003のPIAに相違があることは初耳でした。
http://www.microsoft.com/japan/msdn/office/office2003/OfficePrimaryInteropAssembliesFAQ.aspx
上記の下の方に個別に対応するように書いてありました。
ただ、ソースは不明ですが、ネット上から得た情報では以下の位置付けになっていました。
Excelバージョン : Microsoft Excel Object Libraryのバージョン
97以下 : 8
2000 : 9
2002 :10
2003,XP :11
2003とXPは同じCOMライブラリでいけるようでした。名前空間が違うという情報は見つけられませんでした。
何分、素人のため情報に乏しく返答に時間がかかってしまい申し訳ありません。
もう少し考えて結論が出せましたらレスして解決とさせていただきます。
記事No.7041 のレス /0過去ログ6より /
関連記事表示
削除チェック/
■7066
Re[6]: VBについて
□投稿者/ まる -
(2007/08/29(Wed) 17:00:35)
■
No7065
(PATIO さん) に返信
ご指摘ありがとうございます。
これは個人的にどういうふうに作るのかを知りたくて質問しました。
課題ではないので、今の夏休みの間に具体的なプログラムをみて勉強したいと思ってます。
記事No.7026 のレス /過去ログ18より /
関連記事表示
削除チェック/
<<
0
>>
パスワード/
-
Child Tree
-