WordやExcelで、
起動→文字等入力→印刷→文書クローズ
といったことを自動で行うアプリケーションを作りたいと考えています。
上記をDDEを使って行うつもりでいますが、印刷や文書をクローズといった
制御ができないでいます。
以下まではできています。
1.DDEのInitialize
2.DDEのConnect
3.DdeClientTransactionでトランザクション開始
4.Wordに文字を書く、Excelの特定セルに文字・数値を入れる
印刷や文書クローズするといったWord・Excelそのものを制御するような
DDEメッセージを送るにはどのような手順やDdeClientTransactionで使う
Item名があるか教えて頂けると助かります。
ファイルの関連付けの設定を見ると
[FileOpen("%1")][FilePrint 0][FileExit 2]
というようになっているため、DdeClientTransactionの第4引数(hszItem)
にDdeCreateStringHandleで「FilePrint 0]のHandle作って指定してみま
したがトランザクションに失敗してしまいました。
No.1ベストアンサー
- 回答日時:
Excel のバージョンにもよりますが Visual C++ のソースコードからDDEを使用して操作する前に、次の操作が必要になります。
Excel 2003では、
メニューの ツール>>オプション>>(ダブコントロール)全般>>設定>>ほかのアプリケーションを無視する(このチエックを外す)
DdeCreateDataHandle の関数を DdeCreateStringHandle の代わりに使用して。
idInst はDWORD , hConv をHCONVとして印刷操作は、
char Command[ ]="[Print( )]";
HDDEDATA hData = DdeCreateDataHandle(idInst, (LPBYTE)Command,lstrlen(Command), 0, NULL, CF_TEXT, 0);
DdeClientTransaction((LPBYTE)hData, 0xFFFFFFFF, hConv, 0, 0,XTYP_EXECUTE, TIMEOUT_ASYNC, NULL);
その他、参考までに(バージョン依存している可能性があります。)
//char Command[ ]="[Close]";
//char Command[ ]="[QUIT()]";
//char Command[ ]="[OPEN(\"c:\\x2.xls\")]";
//char Command[ ]="[SAVE.AS?(\"yukika.xls\")]";
//char Command[ ]="[WORKBOOK.SELECT(\"Sheet2\")]";
//char Command[ ]="[SELECT(\"R1C3\")][FONT.PROPERTIES(,\"Bold\")]";
//char Command[ ]="[SELECT(\"R1C3\")][FONT.PROPERTIES(,\"Size\",\"19\")]";
ご返答ありがとうございます。
[]も必要なんですね。
質問がわかりにくい部分あったと思いますがよく理解いただき
ばっちり印刷等できました。
ありがとうございました。
ちなみにwordだと印刷は[print 0]でできました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
charでの計算?
-
文字列から空白を取り除きたい...
-
ネットワークにつながっている...
-
【C言語】テキストファイル内の...
-
c++ 文字列を入力して、一文字...
-
char型からのバイト数取得
-
間接操作のレベルとは
-
atoi( ) の反対をやりたい
-
'const char *' 型は 'char *' ...
-
絶対パスからのファイル名の切...
-
全角文字を含んだ文字の並びを...
-
C言語 文字列操作
-
Visual Studio strcpyについて
-
c言語プログラミング実行時エラ...
-
C言語です
-
テキストデータをそのままバイ...
-
str系関数を使わずに二つの文字...
-
charからLPTSTRへの変換方法
-
char* を渡したとき、不適切なP...
-
int型からchar型への変換
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
CStringをwchar_tに変換したい
-
fgetsなどのときのstdinのバッ...
-
charからLPTSTRへの変換方法
-
C言語のfor文です。 繰り返しの...
-
文字列から空白を取り除きたい...
-
配列をnビットシフトする
-
間接操作のレベルとは
-
charでの計算?
-
テキストデータをそのままバイ...
-
型変換
-
'const char *' 型は 'char *' ...
-
double型の値をchar配列に変換...
-
間接参照のレベルが異なっています
-
干支のプログラム
-
atoi( ) の反対をやりたい
-
C言語です
-
絶対パスからのファイル名の切...
-
ネットワークにつながっている...
-
【C言語】文字型と整数型の違い
-
Win32APIでのエディットボック...
おすすめ情報