
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を探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
配列をnビットシフトする
-
3桁区切(コンマ)記号をつけ...
-
double型の値をchar配列に変換...
-
【C言語】テキストファイル内の...
-
CStringをwchar_tに変換したい
-
Microsoft OfficeをDDEで操作
-
fgetsなどのときのstdinのバッ...
-
バイナリファイルをコピーする...
-
制御の方法
-
const unsigned char *Ptn
-
ランダムな英文字の文字列作成
-
RGB→YUV変換のプログラム
-
文字列ポインタを結合
-
C言語のfor文です。 繰り返しの...
-
C言語 バイナリファイルをfloa...
-
int型のchar型への代入について
-
入力された文字列から整数だけ...
-
javaでunsignedは使えないので...
-
for文 アスタリスクで形を作る
-
文字を16進変換
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
構造体の各メンバにfor文からア...
-
fgetsなどのときのstdinのバッ...
-
文字列から空白を取り除きたい...
-
C言語のfor文です。 繰り返しの...
-
CStringをwchar_tに変換したい
-
間接参照のレベルが異なっています
-
c++ 文字列を入力して、一文字...
-
C言語の入力した文字を反転させ...
-
charからLPTSTRへの変換方法
-
ネットワークにつながっている...
-
'const char *' 型は 'char *' ...
-
テキストデータをそのままバイ...
-
c言語でユーザ関数を利用して入...
-
atoi( ) の反対をやりたい
-
間接操作のレベルとは
-
-'0'の意味について
-
double型の値をchar配列に変換...
-
Linuxでフォルダ内全ファイル名...
-
配列をnビットシフトする
-
型変換
おすすめ情報