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

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

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

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

Q&A

1回答

1627閲覧

【VBA】キーワードを掛け合わせるプログラムを実行する際のエラー

Tsukaji

総合スコア18

VBA

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

0グッド

0クリップ

投稿2020/05/17 13:03

編集2020/05/17 13:48

前提・実現したいこと

カテゴリシートに記載されている各列ごとに掛け合わせを行うプログラムを作成しています。
例:キーワード群1とキーワード群2の掛け合わせの場合
掛け合わせ用シートに該当No.を入力すると
「abcde あいうえお」、「abcde かきくけこ」・・・「fghij さしすせそ」
を表示させる。

イメージ説明

イメージ説明

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

・3語掛け合わせの場合は正しく作動するのに、2語掛け合わせの場合はエラーになる 実行時エラー'1004':  アプリケーション定義、もしくはオブジェクト定義のエラーです。  該当行:  keyword3 = Worksheets("カテゴリ").Cells(4, no3).End(xlDown).Row ・キーワード群の語数が1つの場合、結果が正しく表示されない 例:掛け合わせ作業用シートに1、3、4を入力したとき 以下のように結果が無限に表示されます。 abcde たちつてと まみむめも abcde たちつてと やゆよ abcde たちつてと らりるれろ abcde なにぬねの まみむめも abcde なにぬねの やゆよ abcde なにぬねの らりるれろ abcde はひふへほ まみむめも abcde はひふへほ やゆよ abcde はひふへほ らりるれろ たちつてと まみむめも たちつてと やゆよ たちつてと らりるれろ なにぬねの まみむめも なにぬねの やゆよ なにぬねの らりるれろ はひふへほ まみむめも ・・・

該当のソースコード

Sub KeywordMix() Dim no1 As Integer no1 = Worksheets("掛け合わせ作業用").Cells(4, 2) Dim no2 As Integer no2 = Worksheets("掛け合わせ作業用").Cells(4, 3) Dim no3 As Integer no3 = Worksheets("掛け合わせ作業用").Cells(4, 4) Dim keyword1 As Variant keyword1 = Worksheets("カテゴリ").Cells(4, no1).End(xlDown).Row Dim keyword2 As Variant keyword2 = Worksheets("カテゴリ").Cells(4, no2).End(xlDown).Row Dim keyword3 As Variant keyword3 = Worksheets("カテゴリ").Cells(4, no3).End(xlDown).Row If Worksheets("掛け合わせ作業用").Cells(4, 4) <> "" Then Count = 6 For a = 4 To keyword1 For b = 4 To keyword2 For c = 4 To keyword3 Worksheets("掛け合わせ作業用").Cells(Count, 1).Value = Worksheets("掛け合わせ作業用").Cells(1, no1 + 1).Value & "×" & Worksheets("掛け合わせ作業用").Cells(1, no2 + 1).Value & "×" & Worksheets("掛け合わせ作業用").Cells(1, no3 + 1).Value Worksheets("掛け合わせ作業用").Cells(Count, 2).Value = Worksheets("カテゴリ").Cells(a, no1) & " " & Worksheets("カテゴリ").Cells(b, no2) & " " & Worksheets("カテゴリ").Cells(c, no3) Count = Count + 1 Next c Next b Next a Else Count = 6 For a = 4 To keyword1 For b = 4 To keyword2 Worksheets("掛け合わせ作業用").Cells(Count, 1).Value = Worksheets("掛け合わせ作業用").Cells(1, no1 + 1).Value & "×" & Worksheets("掛け合わせ作業用").Cells(1, no2 + 1).Value Worksheets("掛け合わせ作業用").Cells(Count, 2).Value = Worksheets("カテゴリ").Cells(a, no1) & " " & Worksheets("カテゴリ").Cells(b, no2) Count = Count + 1 Next b Next a End If End Sub

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

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

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

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

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

meg_

2020/05/17 13:08

情報が不足していますので、エラー内容とエラー発生行を質問に追記してください。
Tsukaji

2020/05/17 13:25

失礼いたしました。 ・3語掛け合わせの場合は正しく作動するのに、2語掛け合わせの場合はエラーになる ⇒実行時エラー'1004':  アプリケーション定義、もしくはオブジェクト定義のエラーです。  該当行:  keyword3 = Worksheets("カテゴリ").Cells(4, no3).End(xlDown).Row
Tsukaji

2020/05/17 13:36

・キーワード群の語数が1つの場合、エラーが発生する ⇒実行はされますが、求めている結果が反映されません。 例:キーワード群1をabcdeのみにし、掛け合わせ作業用シートに1、3、4を入力したとき 以下のように結果が無限に表示されます。 abcde たちつてと まみむめも abcde たちつてと やゆよ abcde たちつてと らりるれろ abcde なにぬねの まみむめも abcde なにぬねの やゆよ abcde なにぬねの らりるれろ abcde はひふへほ まみむめも abcde はひふへほ やゆよ abcde はひふへほ らりるれろ たちつてと まみむめも たちつてと やゆよ たちつてと らりるれろ なにぬねの まみむめも なにぬねの やゆよ なにぬねの らりるれろ はひふへほ まみむめも ・・・
meg_

2020/05/17 13:40

ここに書いても回答者の目に触れにくいため、質問に追記してください。
Tsukaji

2020/05/17 13:48

更新したのでご確認ください。
guest

回答1

0

【アプリケーション定義、もしくはオブジェクト定義のエラーについて】

2語掛け合わせの場合にkeyword3 = Worksheets("カテゴリ").Cells(4, no3).End(xlDown).Rowでエラーになるとのことですが、Worksheets("掛け合わせ作業用").Cells(4, 4)が空白の場合no3に0が設定されるためだと思います。
セルに数値が入力されているかを事前にチェックすれば良いでしょう。


<追記>

【キーワード群の語数が1つの場合、結果が正しく表示されないについて】

カテゴリシートの4行目のセルにのみ値が入力されている場合は.End(xlDown).Rowにてシートの最終行である「1048576」を取得します。そのためFor a = 4 To keyword1にてaが1048576になるまでループ処理していると思われます。.End(xlDown).Rowのセルに値が入力されているかどうかチェックすれば良いかと思います。

投稿2020/05/17 14:16

編集2020/05/17 14:27
meg_

総合スコア10762

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

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

Tsukaji

2020/05/17 14:35

ご回答ありがとうございます。 【アプリケーション定義、もしくはオブジェクト定義のエラーについて】 こちらについてですが、2語掛け合わせ、3語掛け合わせの両方に対応できるようにしたいと思っております。 何か良い方法があればご教授願いたいです。 【キーワード群の語数が1つの場合、結果が正しく表示されないについて】 現状のコードですと、キーワード群内のキーワード数が1個しかない場合、正しい結果は得られないという認識でよろしいでしょうか。 可能であれば、1個しかない場合でもプログラムが起動するようにしたいなと考えております。
meg_

2020/05/17 14:42

・no3が0かどうかをチェックして処理を分けるしかないでしょう。 ・回答にも書きましたが「.End(xlDown).Rowのセルに値が入力されているかどうかチェックすれば良いかと思います。」です。値がなければkeywordXXを4にすれば良いです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問