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

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

ただいまの
回答率

91.33%

  • VB.NET

    714questions

    Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。

DataTable型の情報をArrayList型の2次元配列に格納したいです。

解決済

回答 1

投稿 2017/12/01 12:08 ・編集 2017/12/01 13:52

  • 評価
  • クリップ 0
  • VIEW 80

xss

score 12

前提・実現したいこと

お世話になります。
浅い知識でうまくいかず困ってます。。

DataTable型のgetDataStorageにDBから取得したレコードを格納します。
中身の例:
|name|age|gender|
|田中 |28 | 男  |
↓(etc..)

For文を回しgetDataStorageをArrayList型の2次元配列であるarrDataStorageに格納するやり方のコードが知りたいです。
格納したい例:
(0,0)  田中
(0,1)  28
(0,2)  男
(1,0)  篠崎
(1,1)  24
(2,2)  女
↓   etc..

どなたかご教授をよろしくお願いします。

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

エラー    BC30311    型 'String' の値を 'ArrayList' に変換できません。

Array型だとこのようなエラーになってしまう為ArrayList型にしたいです。
'エラー Option Strict On では、遅延バインディングを使用できません。
DirectCast(arrDataStorage(rowsCount), Hashtable)

該当のソースコード

'共通処理 ☆ここをArrayからArrayListにしたい。
Dim arr1 As Array
arr1 = aaaa(引数1,引数2)
'ArrayList型2次元配列を作る関数               ☆変更点As Array→ArrayListにしたい。
Private Function aaaa(ByVal 引数1 As String,ByVal 引数2 As String)As Array 

'DataTable型のgetDataStorageを宣言
Dim getDataStorage As New DataTable
getDataStorage = DBからレコードを取得(引数1,引数2)

'ArrayList型の2次元配列であるarrDataStorageを宣言         ☆変更点 Array→ArrayListにしたい。       
 Dim arrDataStorage(getDataStorage.Rows.Count - 1, getDataStorage.Columns.Count - 1) As ArrayList
    'DataTableをArrayList型二次元配列に格納する
        For x As Integer = 0 To getDataStorage.Rows.Count - 1
            For y As Integer = 0 To getDataStorage.Columns.Count - 1
                     'ここでエラー
                arrDataStorage(x, y) = getDataStorage.Rows(x)(y)

            Next
        Next

       Return arrDataStorage

End Function


'追記:
'何故Array(String)型の2次元配列なのではなく、ArrayList型の2次元配列を作りたい理由として、
'後ほど作ったArrayList型の2次元配列をここでHashtable型にキャストしてFor Eachを回したいからです。

For rowsCount = 0 To ArrayList型の変数.Count - 1
   For Each aaa As DictionaryEntry In DirectCast(ArrayList型の変数(rowsCount), Hashtable)
                               '☆ここでHashtableにキャストしたいがArray型だとエラーになります。
          For Each bbb As DictionaryEntry In   DirectCast(arrDataStorage(rowsCount), Hashtable)


                        Next

                    Next

Next

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

Vb.NET VisualStudio2017

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • xss

    2017/12/04 09:54

    失礼しました。そういう意識は全くありませんでした。気を付けます。

    キャンセル

  • SurferOnWww

    2017/12/04 10:13

    こちらがちょっと神経質すぎました。すみません。

    キャンセル

  • xss

    2017/12/04 10:27

    いえいえ、ご指摘ありがとうございます。改めて質問の際よろしくお願いします。

    キャンセル

回答 1

checkベストアンサー

0

arrDataStorage(x, y) = New ArrayList
arrDataStorage(x, y).Add(getDataStorage.Rows(x)(y))


という形になると思いますが、本当にArrayListの2次元配列にデータを入れるのでしょうか?
ArrayList自体、複数データを扱う配列のような物です。
それの2次元配列ということは
arrDataStorage(0,0)(0)="田中"
arrDataStorage(0,1)(0)="28"
arrDataStorage(0,2)(0)="男"
arrDataStorage(1,0)(0)="篠崎"
arrDataStorage(1,1)(0)="24"
arrDataStorage(2,2)(0)="女"
という感じになるかと思います。

あげている例をみる限り
String型の2次元配列をイメージされているのではないでしょうか?


今一やりたいことというのが理解できていないのですが
DirectCast(arrDataStorage(rowsCount), Hashtable)
としても
エラー    BC30311    型 'ArrayList' の値を 'Hashtable' に変換できません。
となると思います。

また、ForEachで回すということで

       Dim arrDataStorage(getDataStorage.Rows.Count - 1) As ArrayList

        'DataTableをArrayList型二次元配列に格納する
        For x As Integer = 0 To getDataStorage.Rows.Count - 1
            For y As Integer = 0 To getDataStorage.Columns.Count - 1
                arrDataStorage(x) = New ArrayList
                arrDataStorage(x).Add(getDataStorage.Rows(x)(y))
            Next
        Next

        For rowsCount = 0 To arrDataStorage.Count - 1
            For Each columnData In arrDataStorage(rowsCount)

            Next
        Next


こういうことをやりたいのかとも思いましたが、違いますか?

投稿 2017/12/01 12:46

編集 2017/12/01 15:29

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/12/01 13:35

    YAmaGNZさん回答ありがとうございます。
    何故Array(String)型の2次元配列なのではなく、ArrayList型の2次元配列を作りたい理由として、
    後ほど作ったArrayList型の2次元配列をここでHashtable型にキャストしてFor Eachを回したい為です。

    String型の2次元配列の2次元配列だとメソッド自体はエラー無く回るのですがArrayListでは不可能でしょうか・・?
    説明不足で申し訳ございません。

    キャンセル

  • 2017/12/01 19:20

    YAmaGNZさん回答ありがとうございます。
    なんとなく想像はしていましたがForとFor Eachで回したことがなかったのでとても参考になりました。

    キャンセル

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

ただいまの回答率

91.33%

関連した質問

同じタグがついた質問を見る

  • VB.NET

    714questions

    Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。