![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?e8efa67)
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作って指定してみま
したがトランザクションに失敗してしまいました。
![](http://oshiete.xgoo.jp/images/v2/common/profile/M/noimageicon_setting_01.png?e8efa67)
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で質問しましょう!
似たような質問が見つかりました
- 仕事術・業務効率化 文書作成の際の書体や書式について 1 2022/08/29 10:01
- Windows 10 Win10で、IMEパッドをショートカットキーで出せない。 2 2023/01/25 18:45
- プリンタ・スキャナー プリントに関して 3 2023/03/11 15:10
- その他(データベース) Accessフォームからパラメーターで表示したレコードを指定のExcelのセルへ転送する方法について 2 2022/08/22 18:04
- Excel(エクセル) Excel VBAで、行の高さを、上下1文字分程度高くしたい 3 2023/04/23 00:17
- Visual Basic(VBA) 特定の文字を簡単な操作で半角スペースに変換するか削除したい 2 2022/11/01 10:35
- Word(ワード) Wordでの印刷サイズについて A4の原稿をB5サイズで出力したいとき、 印刷から用紙サイズの指定か 4 2022/04/30 09:51
- Excel(エクセル) エクセル2013「次のページ数に合わせて印刷」が小さすぎる 9 2023/03/28 10:18
- ノートパソコン ページ番号の入れ方について 3 2023/02/16 17:11
- Excel(エクセル) エクセルで”入力シート”の文字書式の変更を”出力シート”で同じ文字書式で印刷したいです。VBA希望 4 2023/04/24 11:07
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
charからLPTSTRへの変換方法
-
fgetsなどのときのstdinのバッ...
-
型変換
-
下記のプログラムがコンパイラ...
-
コマンドラインに入力されてい...
-
2曲同時再生するにはどうした...
-
C言語 共用体について コマンド...
-
CStringをwchar_tに変換したい
-
'const char *' 型は 'char *' ...
-
romanize() を使って・・・
-
strtok関数 自作
-
YUV⇔RGB変換がうまくいきません。
-
Microsoft OfficeをDDEで操作
-
TCHAR文字列?の特定部分の数字...
-
ncursesで...
-
wParam
-
C言語 ミリ秒を日付に変換には
-
C言語のポインターで詰まっている
-
Linuxでフォルダ内全ファイル名...
-
atoi を自作するには
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
fgetsなどのときのstdinのバッ...
-
C言語のfor文です。 繰り返しの...
-
テキストデータをそのままバイ...
-
charでの計算?
-
文字列から空白を取り除きたい...
-
charからLPTSTRへの変換方法
-
atoi( ) の反対をやりたい
-
2曲同時再生するにはどうした...
-
C言語の入力した文字を反転させ...
-
配列をnビットシフトする
-
3桁区切(コンマ)記号をつけ...
-
int main()の・・・
-
型変換
-
CStringをwchar_tに変換したい
-
'const char *' 型は 'char *' ...
-
間接操作のレベルとは
-
double型の値をchar配列に変換...
-
絶対パスからのファイル名の切...
-
switch文で文字を比較すること...
-
c++ 文字列を入力して、一文字...
おすすめ情報