質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

Q&A

1回答

1291閲覧

VBA(アプリケーション定義またはオブジェクト定義のエラー時の対応について)

VVVVV

総合スコア1

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

0グッド

0クリップ

投稿2021/11/01 08:59

編集2021/11/01 09:03

前提・実現したいこと

①支店シートのB9~(空白行前)までに入力してある支店コード名のシートを作成し、
シートのA2にその支店コードを入力させたいです。
② ”☆”がつくシートを削除したいです。

発生している問題・エラーメッセージ

すべての支店コード分のシートが正常に作成され、値貼~不要な行削除が行われたあと、
②が実施されずに以下エラーとなりました。

実行時エラー'1004':
アプリケーション定義またはオブジェクト定義のエラーです。

<黄色網掛け行>
.Name = 支店コード.Value

該当のソースコード

VBAです。

Sub 作成()

①Dim 支店コード As Range
For Each 支店コード In Worksheets("支店").Range("B9", Worksheets("支店").Cells(Rows.Count, 2).End(xlUp))
Worksheets("☆原本").Copy After:=Worksheets(Worksheets.Count)
With ActiveSheet
.Name = 支店コード.Value
.Range("A2") = 支店コード.Value
End With

 (値貼)※コード省略
(並び替え)※コード省略
(不要な行削除)※コード省略

 Next 支店コード

②Dim WS As Worksheet
Dim Target As Variant
Dim i As Long
Target = Array("☆")
For Each WS In Worksheets
For i = 0 To UBound(Target)
If InStr(WS.Name, Target(i)) >= 1 Then
Application.DisplayAlerts = False
WS.Delete
Exit For
Application.DisplayAlerts = True
End If
Next i
Next WS

End Sub

試したこと

エラーになった後、②部分のコードのみを実施しましたが、エラーなく完了しました。

補足情報(FW/ツールのバージョンなど)

先ほど、別の質問で①の部分のコード(3行目For each~)を修正いただきましたので、続くコードが誤っているか
「支店」シートの支店コードに問題があるのではと考えています。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hex309

2021/11/02 08:35

エラー時の「支店コード」の値はわかりますか?
VVVVV

2021/11/02 11:46 編集

ご質問有難うございます。 空白前の最後の支店コードは、"060”でした。 このあと、異なる支店群団の支店コード(複数)を貼りなおして試しましたが、同様に すべての支店コード分のシートが正常に作成されたあと、”原本☆(2)”というシートが 作成され、エラーとなりました。 .Name = 支店コード.Value の前に On Error Resume Next を入れてみましたが、”原本☆(2)””原本☆(3)”・・・ とシート作成が続いていったので、ココ↓で空白が空白として認識されていないのではないかと 推測しています。 For Each 支店コード In Worksheets("支店").Range("B9", Worksheets("支店").Cells(Rows.Count, 2).End(xlUp)) 説明を割愛していましたが、「支店コード」も手入力をしたわけではなく、エクセルの関数を利用 して他のシートからもってきていたものです。 関数実施の結果を以下のコードで値にかえ、その結果、ある行から下は「支店コード」のない空白行 のみになっています。 Range("A9:R73").Copy Range("A9").PasteSpecial _ Paste:=xlPasteValues, _ Operation:=xlNone, _ SkipBlanks:=False, _ Transpose:=False
Usirow

2021/11/04 01:46

気になって試してみましたが、シート名に空白を指定しようとしてエラーを吐いているようですね。 関数による生成の場合、見た目空白のセルでも、実際は""(文字数0の文字列)が入っていて空白とみなされていない場合があるので、Worksheets("支店").Range("B9", Worksheets("支店").Cells(Rows.Count, 2).End(xlUp))が本当に狙い通りの範囲を指定しているかを確認をした方がいいかもしれません。
guest

回答1

0

ソース見ないまま書きます(すいません)
経験的によくあるエラーなので推測で書きます。

sheetが異なるところで命令が走ると1004よく出るんですよね。
自分ではActiveだと思っていてもそうではない状態になってると思います。
Sheet名を明確に指定してやってみると解決すると思います。

投稿2021/11/02 14:16

YagiYukio

総合スコア15

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

VVVVV

2021/11/02 14:54

ご回答有難うございます。 ただ、支店シートのB9~(空白行前)までに入力してある支店コード名のシートを作成し、 シートのA2にその支店コードを入力させるという対応は、空白行前までの支店コード分においては 成功しているのです。 そこで次の指令(②)にうつればいいのですが、何らかの理由でループし空白セルのシートが 作成されている (名前が空白のままシートが作成できないので、おそらくコピー元の名前に(2)を つけた"☆原本(2)”になっている)のではと考えていますが、どうでしょうか。
YagiYukio

2021/11/02 16:15

シート名を確認したうえで(IFとかで)進めるとかするといいと思います。 1004は本当に初心者を苦しめるw でもほとんどは想定したシートにいない状態で、作業してるんだと思う
VVVVV

2021/11/03 04:15

有難うございます。 本当に、1004という数字が嫌いになりそうですw エラー内容が曖昧すぎて、初心者には対応できず胃がいたいです。 仰る通り、想定したシートがアクティブになっている状態にあるか、 今一度確認してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問