
いつもお世話になっております。
エクセルブック開いたとき
別プロセスで開き
エクセルを非表示にして
ユーザーフォームだけを起動したいのですが
わかる方おしえてくれませんでしょうか
下記のコードは検索などしてテストしてやっていますが、
どうにもわかりません。
Private Sub Workbook_Open()
Dim xlApp As Excel.Application
Dim xlBook As Excel.Workbook
Set xlSheet = xlBook.Worksheets(1)
Set xlApp = CreateObject("Excel.Application")
Set xlBook = xlApp.Workbooks.Add
Set xlSheet = xlBook.Worksheets(1)
xlSheet.Visible = True
UserForm1.Show vbmodless
Cancel = True
End Sub

No.2ベストアンサー
- 回答日時:
Option Explicit
Private Sub Workbook_Open()
If Workbooks.Count > 1 Then
If Not ThisWorkbook.ReadOnly Then
ThisWorkbook.ChangeFileAccess xlReadOnly, Notify:=False
End If
With New Excel.Application
.Workbooks.Open ThisWorkbook.FullName
End With
If VisibleWindowsCount > 1 Then
ThisWorkbook.Close
Else
Application.Quit
End If
Else
Application.Visible = False
UserForm1.Show vbModeless
End If
End Sub
Private Property Get VisibleWindowsCount() As Long
Dim win As Window
For Each win In Windows
If win.Visible Then
VisibleWindowsCount = VisibleWindowsCount + 1
End If
Next win
End Property
ご返信遅れてすみませんでした。
いろいろ検索しましたが
うまくいかず、
このような コード頂戴
するとはおもいませんでした。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) バックグラウンドのプロセスのエクセルを閉じる方法 4 2022/05/12 15:39
- Visual Basic(VBA) excel VBAでメールを送る方法について 2 2021/11/03 15:34
- Visual Basic(VBA) エラー処理 3 2022/04/11 14:58
- Excel(エクセル) 2つのVBAを一緒にしたら機能しなくなりました(エクセル) 7 2022/06/02 12:41
- Excel(エクセル) VBA Scripting.Dictionary 連想配列 複数参照する方法 2 2021/12/17 01:52
- Visual Basic(VBA) VBA 別ブックからの転記の高速化について VBA 別ブックからの転記の高速化についてご教授下さい。 19 2022/07/26 13:07
- Visual Basic(VBA) VBA Application visibleのやり方 3 2021/11/28 20:51
- Visual Basic(VBA) EXCEL VBA シート貼り付け 3 2021/11/15 12:33
- Visual Basic(VBA) マクロVBA 1シートをまとめる 閉じ方 初心者 SOS! 1 2022/06/17 14:54
- Visual Basic(VBA) サブフォルダ含むすべてのフォルダの Excel 検索 4 2021/12/13 09:33
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
アプリからVB(Form)
-
同じIEのウィンドウで、リンク...
-
Notepad起動のイベントでEXC...
-
リストポックスについて
-
【VB2005】別のプログラムから...
-
フォームの内容をリフレッシュ...
-
VBSから別のVBS起動するとき変...
-
Excelの残骸
-
エクスプローラの終了と再起動...
-
MDIアプリケーションの子ウィン...
-
MSDOS(バッチファイル)でプロセ...
-
gccプログラムで複数の実行ファ...
-
アウトルックが起動しているか...
-
VB6は初心者です。
-
今回、windows 環境下で動くデ...
-
DataGridViewの並び替え
-
ManagementClassが見つからない。
-
vc++ dll excel vba
-
ListViewの使い方
-
「名前'Evaluate'は宣言されて...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBAでOutlookを終了させたい Ex...
-
アウトルックが起動しているか...
-
Process.Startで起動したアプリ...
-
VBで実行中のEXEファイルの情報...
-
Windows上のプログラム。「予め...
-
キー操作 (WSH:コピー&ペー...
-
exeファイルを実行するとすぐに...
-
VBSで起動したアプリが前面表示...
-
EXCEL VBAから他アプリケーショ...
-
VBSから別のVBS起動するとき変...
-
VB6で呼び出し元の情報を取得す...
-
フォームの最前面が効かない
-
gccプログラムで複数の実行ファ...
-
ウィンドウを終了させたい・・・
-
C# 他のアプリケーションを優先...
-
MSDOS(バッチファイル)でプロセ...
-
64bitで作ったEXEを32bitで起動...
-
VBAでSeleniumからChromeを起動...
-
VB6.0からエクセルを起動
-
VBSでExcelのUserFormをエクス...
おすすめ情報
お世話になっております。このサイト先ほど拝見いたしました。
考え方をかえて 最初に別のワークブックにユーザーフォームと
コマンドボタンを作りそこから、
Set xlApp = New Excel.Application
xlApp.Visible = True
Set wb = xlApp.Workbooks.Open(ThisWorkbook.Path & "\ff.xlsx")
で処理すると良い結果がでました。
しかし、最初に開くワークブック
ActiveWindow.Visible = False
UserForm1.Show vbModeless
Cancel = True
とすると ActiveWindow.Visible = False
黄色になります。