LoginSignup
frswataru
@frswataru (本石 渉)

Are you sure you want to delete the question?

Leaving a resolved question undeleted may help others!

VBA 実行自エラー'1004' アプリケーション定義またはオブジェクトエラー

Q&AClosed

解決したいこと

Workbooks(ImportWorkbook).Sheets(1).Range(Cells(1, 1), Cells(eRow2, 23)).Copy
上記のコード実行時下記のエラーが発生します。解決方法をご教授お願いします。

image.png

該当するソースコード

Dim myCon As New ADODB.Connection
Dim myRecordSet As New ADODB.Recordset
Dim mySQL As String
Dim i As Integer
Dim ws1, ws2 As Worksheet
Dim sRow As Long, eRow As Long
Dim sCol As Long, eCol As Long, colCnt As Long
Dim str, codeInfo, Stall1, Stall2, Stall3, Stall4, PreStall1, PreStall2, PreStall3, PreStall4 As String
Private Const mySheetName As String = "作業コードデータ"
Private Const dbFile As String = "\\Vs-picman\Users\admin_SK\TPOD\TPOD.accdb"
Private Declare Sub Sleep Lib "kernel32" (ByVal ms As Long)

Sub Read()


'Application.ScreenUpdating = False ' 描画を停止する





'_________________________変数の宣言1'_________________________

'フォルダの場所を変数に入れる
    Dim Folder_path
    Folder_path = "\\Vs-picman\Users\admin_SK\TPOD_test\TPOD\Export"
'集計するブックを変数に入れる
    Dim ImportWorkbook
    ImportWorkbook = Dir(Folder_path & "\************.xlsx")

  Dim startTime As Double
  Dim endTime As Double
  Dim processTime As Double

'_________________________コピペ処理の実行'_____________________


'指定したフォルダから、Excelファイルを探す
Application.ScreenUpdating = False              '画面の描画更新を停止する

'    Do Until ImportWorkbook = ""
    
        Dim objFileSys As Object
        Dim fileName As String
    
        'ファイルシステムを扱うオブジェクトを作成
        Set objFileSys = CreateObject("Scripting.FileSystemObject")
     
        '拡張子無しのファイル名を取得
        fileName = objFileSys.GetBaseName(Folder_path & "\" & ImportWorkbook)
        Debug.Print fileName
        Set objFileSys = Nothing

        Workbooks.Open fileName:=Folder_path & "\" & ImportWorkbook

         


'Sheet1_________________________________________________________
        
        With Workbooks(ImportWorkbook).Sheets(1).Range("A1").CurrentRegion
            sRow2 = .Item(1).Row
            sCol2 = .Item(1).Column
            eRow2 = .Rows.Count + sRow2 - 1
            eCol2 = 23
            
        End With

        
        '_____________________________________________
        Set ws1 = ThisWorkbook.Worksheets("作業コードデータ")
        '_____________________________________________
        With ws1.Range("A1").CurrentRegion
            sRow = .Item(1).Row + 1
            sCol = .Item(1).Column
            eRow = .Rows.Count + sRow - 1
            eCol = .Columns.Count + sCol - 1
            RowCnt = Cells(Rows.Count, 1).End(xlUp).Row - 1
        End With


        Workbooks(ImportWorkbook).Sheets(1).Range(Cells(1, 1), Cells(eRow2, 23)).Copy
        ThisWorkbook.Activate
        ws1.Cells(eRow, 1).Select
        ActiveSheet.Paste
         
               
      
'            閉じる
            '集計するブックを
        Application.DisplayAlerts = False
            Workbooks(ImportWorkbook).Close
        Application.DisplayAlerts = True
        
        

        

Application.DisplayAlerts = False



'Application.Quit
ThisWorkbook.Close False

Exit Sub

' 後始末
Set fso = Nothing


Application.ScreenUpdating = True                  '画面の描画更新を有効にする



     

'Application.Quit
ThisWorkbook.Close False

     
     

' 後始末
Set fso = Nothing





End Sub








0

5Answer

@frswataru さん

検証は行っておりませんが、
Workbooks(ImportWorkbook).Sheets(1).Range(Cells(1, 1), Cells(eRow2, 23)).Copy

ではなく、
Workbooks(ImportWorkbook.Sheets(1).Range(Cells(1, 1), Cells(eRow2, 23))).Copy

ではないでしょうか。

1

一番可能性が高そうなのはImportWorkbookを指すExcelファイルの中身がVBAのコードが想定する状態になっていなくて
CurrentRegionが上手くいかず結局eRow2の値が0以下になっているからのような気がするなぁ。
そうじゃなかったら一度.でつながってる該当のコードを分解して1行ずつにしてどの部分でエラーが出ているのか探るしかなさそう。

1

コメントになってる描画を停止すればましになるかと
それでも遅いなら複数のExcelファイルをループしてコピペしないといけない構造自体をどうにかしないと無理なんじゃないかな

1

これで回りましたがデータ入力が遅い

Sub Read()


'Application.ScreenUpdating = False ' 描画を停止する



Worksheets(mySheetName).Cells.ClearContents




 Dim row, ws, wb
  Set ws = ThisWorkbook.Worksheets(mySheetName)
  'フォルダ内のブック名を取得
  wb = Dir("\\Vs-picman\Users\admin_SK\TPOD_test\TPOD\Export\" & "*.xlsx")
  Debug.Print wb

  
  
  
  Do While wb <> ""
    'ブックを開く
    Workbooks.Open "\\Vs-picman\Users\admin_SK\TPOD_test\TPOD\Export\" & wb
    'データ部分を取得
    With ActiveWorkbook.Worksheets("Sheet1").Range("A1").CurrentRegion
      row = .Rows("2:" & .Rows.Count)
    End With
    'データを入力
    ws.Cells(Rows.Count, "A").End(xlUp).Offset(1, 0).Resize(UBound(row, 1), 22) = row
    ActiveWorkbook.Close False 'ブックを閉じる
    wb = Dir() '次のブック名を取得
  Loop
  
  
  
End Sub
0

うーむ、色々と。。。
変数は valiant ではなく、それぞれ設定を行った方が。

Dim row As Long
Dim ws As Worksheet
Dim wb As Workbook

あとは、一旦配列に保管してからとか。

0

Your answer might help someone💌