原因は 事前(アーリー)バインディングつまり参照設定をしているためです
yuzumiya氏のパソコンにはExcel2003、ターゲットパソコンにはExcel2000 ということですね
VBのアプリはExcel2003を探しているが見つからないので落ちてしまうのです
As Objectになおして EXcel2003への参照設定も外して EXEを作成してください
質問者
お礼
何度も何度も、回答していただき、本当に有難うございました。
参照設定の「Microsoft Excel 11.0 Object Library」のチェックは外さずに、プログラム内の全ての箇所で(関数の引数も含めて)
以下の修正を行ったところ、他のPCでもエラーが発生することなくきちんとアプリが動作することが出来ました。
As excel.Application ⇒ As Object
As excel.Workbook ⇒ As Object
As excel.Worksheet ⇒ As Object
本当に、ありがとうございました。
質問者
補足
回答有難うございます。
>原因は 事前(アーリー)バインディングつまり参照設定をしているためです
>VBのアプリはExcel2003を探しているが見つからないので落ちてしまうのです
⇒なるほど!VBでExcel2003を探しているため、エラーが発生していたのですね!!
>As Objectになおして EXcel2003への参照設定も外して EXEを作成してください
⇒修正するものは、以下の2点で宜しいでしょうか?
(1)参照設定の「Microsoft Excel 11.0 Object Library」のチェックを外す。
(2)プログラム内の全ての箇所で以下の修正を行う。(関数の引数も含めて)
As excel.Application ⇒ As Object
As excel.Workbook ⇒ As Object
As excel.Worksheet ⇒ As Object
これから、修正してみます。
元の質問の『不正な処理をしている為、このプログラムを終了します』のメッセージは作成したアプリで生成しているメッセージなのでしょうか、それとも Windowsが生成した物ですか?
また補足などに投稿されたコードのどの部分をどのように変更なさったのでしょう
excelfile_openプロシージャは機能しているのでしょうか
もしかして あなたのパソコンにインストールされているExcelは複数ではありませんか
その中の最新版のExcelと他のパソコンのExcelでバージョンが違うのでありませんか
Dim xlApp As excel.Application
といった具合で 事前(アーリー)バインディングするなら使用環境も同じExcelのバージョンである必要があります
違うバージョンが存在するなら
excelfile_openの中でやっているように Excel関連のオブジェクトを
As Objectで宣言して使いましょう
開発時は アーリーバインディングデングでインテリセンスを使いながら開発したほうが効率的でしょう
リリース時点で As Objectに置き換え
Excel.Applicationを新規に起こす場合は CreateObjectまたはGetObjectを使いましょう
質問者
お礼
回答有難うございます。
助言頂いた箇所を、以下のように修正を行いましたが、やはり同じエラーが発生してしまいました。
--------------------------------
Private Sub Combo2_Click()
Dim i As Integer
Dim xlApp As Object ← 修正後
Dim xlBook As Object ← 修正後
Dim xlSheet As Object ← 修正後
' Dim xlApp As excel.Application ← 修正前
' Dim xlBook As excel.Workbook ← 修正前
' Dim xlSheet As excel.Worksheet ← 修正前
Dim fa As String, excelfile_path As String, terminal As String
Dim Msg As String, Style As Integer, Title As String
Dim terminal_Column As Integer, path_Column As Integer, path_name As String, Del_Line As Boolean
'エクセルのファイルパス名
fa = App.Path
If Right(fa, 1) <> "\" Then fa = fa & "\"
excelfile_path = fa & Text8.Text & Label7
'比較EXCELファイルの存在確認
If comp_excelfile_check(excelfile_path) = False Then Exit Sub
Combo3.Enabled = False
Combo3.Clear
Combo3.Text = "(商品を選択してください)"
Call excelfile_open(xlApp, xlBook, xlSheet, excelfile_path, "【参考】シート名")
terminal = Combo2.Text
i = xlSheet.Range("C13:C65536").Find(terminal, , , xlPart, , , , False).Row
Do While xlSheet.Cells(i, 3).Text = terminal
Combo3.AddItem xlSheet.Cells(i, 4).Value
i = i + 1
Loop
Combo3.Enabled = True
Check5.Visible = False
Check5.Value = 2
Check12.Visible = False
Check12.Value = 2
End Sub
--------------------------------
まだ、どこかおかしいのでしょうか?
ゴメンなさい。もう一つ、エクセルファイルを開くプログラムを記載し忘れてしまいました。
以下になります。
Sub excelfile_open(xlApp As excel.Application, xlBook As excel.Workbook, xlSheet As excel.Worksheet, ByVal excelfile_path As String, ByVal sheet_name As String)
'エクセルファイルの取得
Dim excelfile_name As String
excelfile_name = Mid(excelfile_path, InStrRev(excelfile_path, "\") + 1)
On Error Resume Next
'エクセルを起動して、ファイルを開く
'Set xlApp = CreateObject("Excel.Application")
'Set xlBook = xlApp.Workbooks.Open(ExcelFile_path)
Set xlApp = GetObject(, "Excel.Application")
If Err.Number <> 0 Then
Set xlApp = CreateObject("Excel.Application")
Err.Clear
End If
Set xlBook = xlApp.Workbooks(excelfile_name)
If Err.Number <> 0 Then
'保存確認のメッセージを非表示にする。
xlApp.DisplayAlerts = False
Set xlBook = xlApp.Workbooks.Open(excelfile_path)
xlApp.DisplayAlerts = True
End If
Set xlSheet = xlBook.Worksheets(sheet_name)
On Error GoTo 0
'エクセルを表示します。(表示しなくてもOK)
'xlApp.Visible = True
End Sub
よろしくお願い申し上げます。
質問者
補足
回答有難うございます。返信遅れてもうしわけありませんでした。
exeは起動します。
イベント実行時にエラーが発生してしまいます。
exeを起動させると、ファイル名を入れるtextboxやアイテムを入れるcomboboxが表示されます。
イメージとしては、エクセルファイルにA社~D社で扱っている商品が表で纏めてあります。
そして、1つめのcombo.boxをクリックするとA社,B社,C社,D社と選べるようになり、これを選択すると、2つめのcombo.boxに、選んだ会社で扱っている商品が選べるようにcombo.boxのプルダウンに設定されるというものになります。
エラーが発生するのは、このcombo.boxでA社~D社を選択した時です。
エクセルファイルを開くプログラムで何かおかしな事になっている可能性があるのですが、この辺りは全く私は手を出していません。
いじる必要がありませんので、いじっていないのですが・・・。
その辺りのプログラムは以下の通りです。
Private Sub Combo2_Click()
Dim i As Integer
Dim xlApp As excel.Application
Dim xlBook As excel.Workbook
Dim xlSheet As excel.Worksheet
Dim fa As String, excelfile_path As String, terminal As String
Dim Msg As String, Style As Integer, Title As String
Dim terminal_Column As Integer, path_Column As Integer, path_name As String, Del_Line As Boolean
'エクセルのファイルパス名
fa = App.Path
If Right(fa, 1) <> "\" Then fa = fa & "\"
excelfile_path = fa & Text8.Text & Label7
'比較EXCELファイルの存在確認
If comp_excelfile_check(excelfile_path) = False Then Exit Sub
Combo3.Enabled = False
Combo3.Clear
Combo3.Text = "(商品を選択してください)"
Call excelfile_open(xlApp, xlBook, xlSheet, excelfile_path, "【参考】シート名")
'エクセルを表示します。(表示しなくてもOK)
'xlApp.Visible = True
terminal = Combo2.Text
i = xlSheet.Range("C13:C65536").Find(terminal, , , xlPart, , , , False).Row
Do While xlSheet.Cells(i, 3).Text = terminal
Combo3.AddItem xlSheet.Cells(i, 4).Value
i = i + 1
Loop
Combo3.Enabled = True
Check5.Visible = False
Check5.Value = 2
Check12.Visible = False
Check12.Value = 2
End Sub
Function comp_excelfile_check(ByVal excelfile_path As String) As Boolean
'比較EXCELファイルの存在確認
Dim Msg As String, Style As Integer, Title As String
Dim excelfile_name As String
excelfile_name = Mid(excelfile_path, InStrRev(excelfile_path, "\") + 1)
If Dir(excelfile_path, vbNormal) = "" Then
Msg = "比較ファイル『" & excelfile_name & "』が見つかりません。" ' メッセージを定義します。
Style = vbExclamation ' ボタンを定義します。
Title = "注意" ' タイトルを定義します。
MsgBox Msg, Style, Title
comp_excelfile_check = False
Else
comp_excelfile_check = True
End If
End Function
ちなみに、EXCELファイルの存在確認である、comp_excelfile_checkプログラムでは、存在しないファイル名で行うと、きちんと「ファイルが存在しません」とメッセージが出力されるので、ここまでは問題なく動いていることは分かっています。
お礼
何度も何度も、回答していただき、本当に有難うございました。 参照設定の「Microsoft Excel 11.0 Object Library」のチェックは外さずに、プログラム内の全ての箇所で(関数の引数も含めて) 以下の修正を行ったところ、他のPCでもエラーが発生することなくきちんとアプリが動作することが出来ました。 As excel.Application ⇒ As Object As excel.Workbook ⇒ As Object As excel.Worksheet ⇒ As Object 本当に、ありがとうございました。
補足
回答有難うございます。 >原因は 事前(アーリー)バインディングつまり参照設定をしているためです >VBのアプリはExcel2003を探しているが見つからないので落ちてしまうのです ⇒なるほど!VBでExcel2003を探しているため、エラーが発生していたのですね!! >As Objectになおして EXcel2003への参照設定も外して EXEを作成してください ⇒修正するものは、以下の2点で宜しいでしょうか? (1)参照設定の「Microsoft Excel 11.0 Object Library」のチェックを外す。 (2)プログラム内の全ての箇所で以下の修正を行う。(関数の引数も含めて) As excel.Application ⇒ As Object As excel.Workbook ⇒ As Object As excel.Worksheet ⇒ As Object これから、修正してみます。