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

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

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

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

Q&A

解決済

1回答

5409閲覧

動的配列にRangeで範囲の値を一括代入 データ数1以下でエラー

khtt

総合スコア1

VBA

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

0グッド

0クリップ

投稿2020/05/13 11:56

前提・実現したいこと

Exce2016でVBAによるシステムを構築しています。
動的配列に、ある範囲の値を一括で代入する方法を検討しています。

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

データ数が2以上(2行以上)であればエラーは発生しないのですが、
1以下だと「実行時エラー13 型が一致しません」のエラーが発生します。

該当のソースコード

Sub test1()

Dim rowcount As Variant
Dim data() As Variant

rowcount = Cells(Rows.Count, 1).End(xlUp).Row

ReDim data(rowcount, 0)
data = Range(Cells(1, 1), Cells(rowcount, 1)).Value

End Sub

試したこと

forのループでセルの値を一つ一つ配列に代入する方法であれば
データ数が1でもエラーが発生しなかったので取り急ぎその方法で回避しました。
上記のRangeを使うコードは誤りなのでしょうか。

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

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

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

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

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

guest

回答1

0

ベストアンサー

エラーを回避する方法として、データ数1を別処理としてみました。
この場合、Option Base 1 を用い、配列のインデックスを1始まりとすれば、
動的配列にセル範囲を一括で代入する場合とも整合が図れます

VBA

1Option Explicit 2Option Base 1 3 4Sub test1() 5 6 Dim rowcount As Long '数値なのでLong型 7 Dim data() As Variant 8 9 rowcount = Cells(Rows.Count, 1).End(xlUp).Row 10 11 If rowcount = 1 Then 12 ReDim data(1, 1) 13 data(1, 1) = Cells(1, 1).Value 14 Else 15 data = Range(Cells(1, 1), Cells(rowcount, 1)).Value 16 End If 17End Subド

投稿2020/05/13 14:00

TanakaHiroaki

総合スコア1063

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

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

khtt

2020/05/14 11:32

ご回答ありがとうございました。 早速この処理を取り入れてみたいと思います。 なぜこのエラーが発生するか、理由についてもご教授いただけますと幸いです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問