For~Next構文内でシートコピーしていると途中で、
実行時エラー'1004’
WorksheetクラスのCopyメソッドが失敗しました。
が表示されることがあります。
該当のFor~Next文は10回以上実行されているので、コードの誤りではないと思うのですが、なぜ「Copyメソッドが失敗」するのかわかりません。
理由/対処方法がわかればありがたいと思い質問させていただきます。
**該当コード**
Sub 評価シート作成()
Sheets(社員一覧).Select
行 = 1
Do
ReDim Preserve 社員CD(行)
ReDim Preserve 氏名(行)
社員CD(行) = Cells(行 + 1, 1).Value
氏名(行) = Cells(行 + 1, 2).Value
行 = 行 + 1
Loop Until Cells(行, 1) = ""
人数 = 行 - 2
For 回数 = 1 To 人数
Sheets(評価シート).Select
Sheets(評価シート).Copy after:=Sheets(評価シート)
ActiveSheet.Name = 氏名(回数)
Cells(4, 5) = 氏名(回数)
Cells(4, 3) = 社員CD(回数)
Next 回数
End Sub
*****************************
よろしくお願いします
No.3ベストアンサー
- 回答日時:
ひょっとしてこれに該当するのかな?
Excel でプログラムを使用してワークシートをコピーするとランタイム エラー 1004 が発生する
http://support.microsoft.com/kb/210684/ja
No.4
- 回答日時:
こんにちは。
コードとしては、失礼ですが、動的配列を使いながら、2バイト文字変数では、ものすごくバランスが悪いです。申し訳ないのですが、私には、修正とかいうレベルではないです。2バイト文字の変数のオンパレードはミスの元です。動的配列を使いたい気持ちは分からないわけではないけれども、そのためには、もう少し、初歩的な技術の蓄積が必要ではないでしょうか。
もともと、そのコードでは動くわけないのでしょうから、掲示板に載せるために、相当に省いているのか加工しているのだと思います。
Sheets("評価シート").Copy after:=Sheets("評価シート")
"" のクォーテーションは、どうなっているのでしょうか?
ActiveSheet.Name = 氏名(回数)
これも、実にエラーが発生しやすいです。
それから、
For i = Rng.Rows.Count To 1 Step -1
左から順に入れていくなら、このように逆にしたほうがよいのではないでしょうか。これは一例です。
Sub EvaluationSheetMaking()
Dim Sh1 As Worksheet
Dim Sh2 As Worksheet
Dim Rng As Range
Dim i As Long
Set Sh1 = Worksheets("社員一覧")
Set Sh2 = Worksheets("評価シート")
With Sh1
Set Rng = .Range("A2", .Range("A65536").End(xlUp).Offset(, 1))
End With
For i = Rng.Rows.Count To 1 Step -1
On Error Resume Next
Sh2.Copy After:=Sh2
With ActiveSheet
.Name = Rng.Cells(i, 2).Value
.Cells(4, 5) = Rng.Cells(i, 2).Value
.Cells(4, 3) = Rng.Cells(i, 1).Value
End With
On Error GoTo 0
Next i
Set Rng = Nothing
End Sub
No.1
- 回答日時:
> ActiveSheet.Name = 氏名(回数)
のところが怪しい気がするんですが
実際はどの行でストップしてますか?
コードの該当行が反転しているはずですが
シート名に設定しようとしたデータ:氏名(回数)が空っぽとかではない?
この回答への補足
Sheets(評価シート).Copy after:=Sheets(評価シート で停止します。
何度か実行していますが同じ行数のところで失敗になります。
そうなるとワークシートから手作業でシートコピーしようとしてもできません。
一旦エクセルを終了→エクセルのみ再起動し、(シート名が重ならないよう)データを入替えて実行すれば、その前より少ない行数で失敗します。
なぜなのか見当もつきません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) Excelで下記のようにマクロを作ったところ、一回目は実行できたのですが、二回目以降「実行時エラー1 1 2022/03/25 08:08
- Visual Basic(VBA) コード名シートA列と集計シートA列のコードが一致したら、コード名シートA5からk12の範囲をコピーし 1 2022/08/29 23:46
- Visual Basic(VBA) 集計シートA列のコードと一致する右に並んだシート名(コード)の3行目から10行目をコピーして貼り付け 4 2022/08/18 15:24
- Excel(エクセル) マクロで最終行から上に検索を逆にしたい 1 2022/05/17 18:27
- Visual Basic(VBA) VBAでのループ順序について 3 2023/03/13 10:55
- Visual Basic(VBA) excel vbaでvlooupの変数がわかりません。 7 2022/05/30 09:35
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Visual Basic(VBA) ExcelVBAでDo Until loopのネスト、IF文を使って一致する物と一致しない物としたい 11 2022/12/24 17:46
- Visual Basic(VBA) まとめシートから集計シートへA列のコードが一致したら1行コピーするマクロをネット上で見つけました。こ 1 2022/08/30 14:11
- Excel(エクセル) なぜExit Subがあるのかわかりません 4 2023/02/19 12:34
このQ&Aを見た人はこんなQ&Aも見ています
-
外出時に「待たせる妻」vs イライラする「待つ夫」は日本だけ?見習いたい海外事情
夫の家事参加に積極的なイメージのある海外でも、同様の事例はあるのか。結婚カウンセラーの佐竹悦子さんに伺ってみた。
-
worksheetクラスのcopyメソッドが失敗しました。
その他(Microsoft Office)
-
VBA シートをコピーする際に Copyメソッドは失敗しましたのエラーが出てしまいます
Visual Basic(VBA)
-
EXCEL VBA シートをコピーする時にエラーが発生してしまう件
Excel(エクセル)
-
-
4
Excel2003でworksheetクラスのCopyメソッドが失敗し
Visual Basic(VBA)
-
5
エクセルでコピーができなくなる
Visual Basic(VBA)
-
6
VBA マクロ実行時エラー’1004RangeクラスのPasteSpecialメソッドが失敗
Access(アクセス)
-
7
Access VBAから使用したExcelプロセスを閉じる方法について
Visual Basic(VBA)
-
8
エクセルのエラーメッセージ「400」って?
Visual Basic(VBA)
-
9
ACCESSのVBAにてExcelのシートをコピーしたい
その他(データベース)
-
10
ExcelVBA Range クラスの PageBreak プロパティを設定できません。
Visual Basic(VBA)
-
11
VBAでシートコピー後、シート名が重複している時の処理
Access(アクセス)
-
12
AccessVBAでExcelを起動し、罫線を引きたいのですが、Exc
Visual Basic(VBA)
-
13
'Range'メソッドは失敗しました
Excel(エクセル)
-
14
実行時エラー -'-2147417848
Excel(エクセル)
-
15
VBA Shapes コピーと名前
Excel(エクセル)
-
16
Accessで別テーブルの値をフォームに表示したい
その他(データベース)
-
17
VBAマクロ 実行時エラーが出たり出なかったり
Excel(エクセル)
-
18
Excel vbaについての質問
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
前の(左隣の)シートを連続参...
-
Excelで同じシートのコピーを一...
-
エクセルVBAでパスの¥マークに...
-
スプレッドシートの関数VLOOKUP...
-
エクセルの複数シートの保護を...
-
別シート参照のセルをシート毎...
-
複数シートの色付きセルがある...
-
EXCEL:同じセルへどんどん足し...
-
Excelで金銭出納帳。繰越残高を...
-
シートの保護のあとセルの列、...
-
エクセルでファイルを開いたと...
-
エクセルで前のシートを連続参...
-
excelでシート毎の最終更新日を...
-
エクセル 計算式も入っていない...
-
複数のピボットを同じフィルタ...
-
シート番号からシート名を取得する
-
VBAでシートコピー後、シート名...
-
エクセルで前シートを参照して...
-
Accessのスプレッドシートエク...
-
Excelのシートを、まとめて表示...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excelで同じシートのコピーを一...
-
エクセルの複数シートの保護を...
-
Excelで金銭出納帳。繰越残高を...
-
エクセルでファイルを開いたと...
-
EXCELで1ヶ月分の連続した日付...
-
エクセルVBAでパスの¥マークに...
-
EXCEL:同じセルへどんどん足し...
-
シートの保護のあとセルの列、...
-
別シート参照のセルをシート毎...
-
エクセルで前のシートを連続参...
-
前の(左隣の)シートを連続参...
-
EXCELで同一フォーマットのシー...
-
VBAでシートコピー後、シート名...
-
Excel 連番を入力する方法
-
エクセル 計算式も入っていない...
-
エクセルで前シートを参照して...
-
エクセルでシート名を自動入力...
-
Accessのスプレッドシートエク...
-
複数シートの特定の位置に連番...
-
エクセルのシート名をリスト化...
おすすめ情報