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

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

ただいまの
回答率

87.59%

[c#]リスト化した配列を検索し表示させる方法

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,785

score 18

csvファイルを読み込み、すべて配列化しリスト化しました。

リスト内の名前を検索し、同配列内の個別の情報が各テキストボックス内に表示されるようにしたいです。

まず試したことはインデックスを取得し表示させようと思ったのですが、取得できずエラーが出てしまいます。

取得した後に配列を指定する[]内に入れることができないかもしれませんが....

何かいい方法がないかと数日悩んでおりますが解決策が見つからないので質問させていただきました。
よろしくお願いいたします。

public partial class Form1 : Form
    {
        public static List<string[]> csvData = new List<string[]>();

        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            // csv読込み
            LoadCsv();
        }

        public void LoadCsv()
        {
            try
            {
                // csvファイルを開く
                using (var sr = new System.IO.StreamReader(@"test.csv"))
                {
                    //ヘッダを読み捨てる。
                    sr.ReadLine();
                    // ストリームの末尾まで繰り返す
                    while (!sr.EndOfStream)
                    {
                        // CSVファイルの一行を読み込む
                        string line = sr.ReadLine();
                        // 読み込んだ一行をカンマ毎に分けて配列に格納する
                        string[] record = line.Split(',');
                        // リストに追加
                        csvData.Add(record);
                    }
                }
            }
            catch (System.Exception e)
            {
                // ファイルを開くのに失敗したとき
                MessageBox.Show("ファイルの読み込みに失敗しました。", "エラー", MessageBoxButtons.OK,
                            MessageBoxIcon.Error);
            }
        }

        // 表示ボタン
        private void buttonView_Click(object sender, EventArgs e)
        {
            string InputID = textBoxName.Text;
            int num = csvData.IndexOf(InputID);   //エラー //ここで取得した値は下の[]内にいれることはできるのだろうか...?

            textBoxName.Text = csvData[0][0];
            textBoxAge.Text = csvData[0][1];
            textBoxGender.Text = csvData[0][2];
            textBoxAddress.Text = csvData[0][3];
            textBoxTelText = csvData[0][4];
        }
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • moconyan

    2019/03/08 10:09

    KoichiSugiyama様

    テキストボックスに名前を入力し、それに紐づいた住所や電話番号を各テキストボックスに表示させたいということです。
    わかりずらくてすみません...。

    キャンセル

  • ebiryo

    2019/03/08 10:41

    同じ名前が複数ある可能性は考慮しなくて良いのですか?

    キャンセル

  • moconyan

    2019/03/08 10:49

    ebiryo様
    はい、同じ名前の場合は考慮しなくて大丈夫です!

    キャンセル

回答 1

checkベストアンサー

+2

InputIDは名前とのこと。
var theRow = csvData.FirstOrDefault(x => x[0] == InputID);で1列目がInputIDに等しいものがあれば一つ、なければnullが取れるので、textBoxName.Text = theRow[0];などとするのが簡便ではないかと思います。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/03/08 10:47

    こちらのコードに修正後、無事表示することができました!!
    ご回答くださったコードも理解したのち進めていきたいと思います。

    ご回答くださった皆さん、本当にありがとうございます。


    ```c#
    // 表示ボタン
    private void buttonView_Click(object sender, EventArgs e)
    {
    string InputID = textBoxName.Text;
    var theRow = csvData.FirstOrDefault(x => x[0] == InputID);

    textBoxName.Text = theRow[0];
    textBox.Age = theRow[1];
    textBoxGender.Text = theRow[2];
    textBoxAddress.Text = theRow[3];
    textBoxTel.Text = theRow[4];
    }
    ```

    キャンセル

  • 2019/03/08 10:49

    最低限nullチェックはしたほうがいいですよ。
    FirstOrDefaultだと名前がマッチしなかったとき、theRowはnullになり、theRow[0]で例外となります。

    キャンセル

  • 2019/03/08 10:55

    papinianus様

    ご指摘ありがとうございます。
    そうですね、今のままですとnullの場合と存在しない名前の場合処理が止まってしまうので例外処理を足し行きたいと思います。ありがとうございます。

    キャンセル

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

  • ただいまの回答率 87.59%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

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