Excel2003でworksheetクラスのCopyメソッドが失敗しました。
という表示がでて全く原因がわからず困っています。
詳細は
ThisWorkbook.Worksheets("請求書・原本").Copy Before:=Worksheets(sheetname2)
の箇所でエラーが発生します。
発生する場所はたまに変わります。
すぐ上のプロシージャで実行している同じようなステートメントは問題なく実行されるのですが、
急に同じ構文の箇所で発生しているので全く理由がわかりません。
変数で設定しているシート名は確実に存在しています。
コードは以下のとおりです。
Function fncPrtCon2(ByVal sheetname As String, ByVal siki As String, ByVal mainScr As String, ByVal i As Long)
'【変数】
Dim wDate As Date '日付入力用変数
Dim xDate As Date
Dim work As String '日付フォーマット用
Dim sheetname2 As String
ThisWorkbook.Worksheets("明細・原本").Copy Before:=Worksheets("明細・原本")
sheetname = sheetname & "・" & Worksheets(mainScr).Cells(i + 1, 6).Value & "・明細"
ActiveSheet.Name = sheetname
sheetname2 = sheetname
(中略)
'原本シートコピー
ThisWorkbook.Worksheets("請求書・原本").Copy Before:=Worksheets(sheetname2)
sheetname = Replace(sheetname, "・明細", "")
ActiveSheet.Name = sheetname
End Function
上記コードはサブモジュールでメインから各引数を値渡ししています。
Copyメソッドの引数を省略して実行すると成功します。
どこか問題のある箇所があるでしょうか。
助言お願いします。
No.2ベストアンサー
- 回答日時:
>エラーが発生します。
これだけでは、いろいろな事が考えられるので、憶測でしか物を言えません。
エラーが出ているときは、エラーメッセージも載せるようにしましょうね。
引数のBefore:=Worksheets(sheetname2)
↑
このシート「Worksheets(sheetname2)」は、アクティブなワークブックに存在しているシートではないとか?
Before:=Workbooks("Book1.xlsなどのブック名").Worksheets(sheetname2)
という感じにしてあげるとうまくいくかもしれません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 【ご教示ください】VBAの記述方法がわかりません。 2 2022/08/12 21:28
- Visual Basic(VBA) 別シートから年齢別の件数をカウントしたいの続き 5 2023/01/24 00:16
- Visual Basic(VBA) VBA 別ブックからの転記の高速化について VBA 別ブックからの転記の高速化についてご教授下さい。 19 2022/07/26 13:07
- Visual Basic(VBA) 【前回の続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/16 16:44
- Visual Basic(VBA) 別シートのデータを参照して値を入れたい。 まとめデータシートのC列D列の値を商品一覧シートのコードが 7 2022/08/17 13:20
- Visual Basic(VBA) 【前回の続き続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/24 20:49
- Visual Basic(VBA) 稀に1円合いません? Sheet1から金額と個数を貼り付ける下記コードで、金額を切り上げるコードを何 3 2022/09/05 15:11
- Visual Basic(VBA) excel vbaでvlooupの変数がわかりません。 7 2022/05/30 09:35
- Visual Basic(VBA) ExcelVBAに関する質問 3 2023/02/17 10:47
- Excel(エクセル) VBA でvlookup エラーなどは削除したい 8 2022/12/30 04:03
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
VBA シートをコピーする際に Copyメソッドは失敗しましたのエラーが出てしまいます
Visual Basic(VBA)
-
worksheetクラスのcopyメソッドが失敗しました。
その他(Microsoft Office)
-
エクセル マクロ実行時エラー’1004’
Excel(エクセル)
-
-
4
EXCEL VBA シートをコピーする時にエラーが発生してしまう件
Excel(エクセル)
-
5
Excel VBA シート名変更時、重複していたら連番を付けたい
その他(Microsoft Office)
-
6
Worksheets メソッドは失敗しました。のエラー処理のやり方
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
実行時エラー 438になった時の...
-
エクセルエラー13型が一致しま...
-
日本語環境下で作成したマクロ...
-
なぜこんな初歩的なVBAのIf文で...
-
VBS実行時エラー オブジェクト...
-
【Excel VBA】マクロをボタンに...
-
Application.ActiveInspectorで...
-
ExcelVBA Range クラスの Page...
-
職場から目的地までの距離集計
-
プロシージャ名の取得
-
実行時エラー3001「引数が間違...
-
なぜエラーになるのでしょうか...
-
Access2003、2010間の非互換?
-
エクセルVBA、フリーフォームで...
-
ExcelのVBAのAutoFillの使い方...
-
Excel2019 ワークシートのコピ...
-
VBA 別シートのセルから、文字...
-
VBAのChrome操作のエラーについ...
-
【エクセル】ハイパーリンク先...
-
VBSで変数の宣言はできないので...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
実行時エラー 438になった時の...
-
エクセルエラー13型が一致しま...
-
【Excel VBA】マクロをボタンに...
-
VBAでのエラー
-
マクロについて教えてください...
-
なぜこんな初歩的なVBAのIf文で...
-
VBAがブレークモードになっ...
-
実行時エラー3001「引数が間違...
-
ExcelVBA Range クラスの Page...
-
VBS実行時エラー オブジェクト...
-
EXCEL VBAマクロ中断でデバッグ...
-
Outlook.ApplicationをCreateOb...
-
VBSで変数の宣言はできないので...
-
VBAのコードがエラーになっ...
-
実行時エラー -'-2147417848
-
ADODB.Streamを使用してUTF-8を...
-
EXCEL/VBAで、自分のPCだけエラ...
-
OLEDB.NETで接続できない
-
プロシージャ名の取得
-
VB6+SQL サーバー 2000 で 実行...
おすすめ情報