三流君 ken3のmemo置き場

三流プログラマーのメモ書きです。主にVBAやWindowsの話題が多いです

挨拶・自己紹介:
失敗続きのAB型の変わり者 :三流プログラマー Ken3です
フリーのエンジニア・個人事業主です・・と書くと聞こえはイイが(それとなくカッコよく聞こえるが)、 現在は小さな案件の受注請負 と 短期派遣 で 日々つつましく?ほそぼそと暮らしてます。

よく検索されるキーワード: [質問回答XXXXさんへ] [CreateObject] [VBA] [JRA競馬オッズ]

AccessからExcelを起動してファイルを開く、そんなマクロ(VBA)

5.AccessのデータをExcelへ転記する

まだまだ、穴があり、改良の余地がある入力画面をほっといて(おいおい)
次は、データをExcelに書き出してみたいと思います。

操作の動画↓
www.youtube.com
http://www.youtube.com/watch?v=TRRc_fDH1Xk

5.1 Excel ひな型(テンプレート)ファイルの用意

まず、罫線付き、フォーマットが整ったExcelファイルを用意します。
(※白紙から作る方法もありますが、今回は事前に準備します。)

↑テンプレート.xls として、作成します。

5.2 AccessからExcelを起動します(ウイザードで楽に作ります)

次にAccessからExcelを起動します。
ここでは、ウィザードを利用して作ってみます。

↑まぁ、普通にボタンを選択するとウィザードが立ち上がるので、
 アプリケーション -- Excelの起動
 を選択します。

すると、下記のコードが自動的に作成されます。

Private Sub コマンド0_Click()
On Error GoTo Err_コマンド0_Click

    Dim oApp As Object

    Set oApp = CreateObject("Excel.Application")
    oApp.Visible = True
    'Only XL 97 supports UserControl Property
    On Error Resume Next
    oApp.UserControl = True

Exit_コマンド0_Click:
    Exit Sub

Err_コマンド0_Click:
    MsgBox Err.Description
    Resume Exit_コマンド0_Click
    
End Sub

5.3 作成済みのひな型(テンプレート)ファイルを開きます

まず、Excel側でマクロを記録します。
ツール -- マクロ -- 新しいマクロの記録 を選択します。

次に、ファイル -- 開く で 先ほど作成した テンプレート.xlsを開きます。
開いたら、マクロの記録を終了させます。

作成されたマクロ(Excel VBA)を確認するには、
ツール -- マクロ -- Visual Basic Editor を選択します。
(alt+F11キーでもOKです。)
標準モジュールにマクロが作成されています。

Option Explicit

Sub Macro1()
'
' Macro1 Macro
' マクロ記録日 : 2009/11/24  ユーザー名 : user2000
'

'
    ChDir "E:\WORK"
    Workbooks.Open Filename:="E:\WORK\テンプレート.xls"
End Sub

↑作成された.xlsファイルを開くマクロ(VBAの命令)↓をコピーします
Workbooks.Open Filename:="E:\WORK\テンプレート.xls"

Access側に戻り、
記録したマクロ(コピーしたマクロ)をAccess側に貼り付けます。
頭にExcel参照用の変数 ここではoAppを付けます。

Option Compare Database
Option Explicit

Private Sub コマンド0_Click()
On Error GoTo Err_コマンド0_Click

    Dim oApp As Object

    Set oApp = CreateObject("Excel.Application")
    oApp.Visible = True
    'Only XL 97 supports UserControl Property
    On Error Resume Next
    oApp.UserControl = True

    oApp.Workbooks.Open Filename:="E:\WORK\テンプレート.xls"
    '↑頭にoAppとAccessからExcelを参照する変数を付ける

Exit_コマンド0_Click:
    Exit Sub

Err_コマンド0_Click:
    MsgBox Err.Description
    Resume Exit_コマンド0_Click
    
End Sub

Excelを閉じ、Accessのボタンを押してテストします。
無事にひな型(テンプレート)が開かれたことを確認します。

Ken3 ホームページ 目次

分類:HPを大きく分けると4つの柱(分類)です。

  1. [VBA・マクロ プログラミング]の解説
    当店の人気はVBA系のCreateObject("XXXXXX.application")で他のアプリケーションを操作するサンプルが人気です
  2. [プログラマーの愚痴]では、あまり見せたくない三流プログラマーの内面かな。
    三流君を踏み台にする
  3. [古いクラシック ASP(Active Server Pages)]の解説。
  4. [元コンビニ店長時代の話]が弟に巻き込まれ、失敗した脱サラ、畑違い?の仕事で失敗。
主に上記4つの分類でHP作成やメルマガの発行を行ってます。
※更新頻度が落ちていて情報の鮮度が悪いです。



本当に三流なんです(笑):たまにスゴイですねなんて言われることもありますが、
真実は→ [三流君の真実は...] ←を初めに見てくださるとわかると思います。
(からくりは、成功例↑しか載せてなくて ヒドイ失敗例はお蔵入り迷宮入りが多かったりします)