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

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

新規登録して質問してみよう
ただいま回答率
85.50%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

Q&A

解決済

2回答

8141閲覧

C# DataSourceで中身を設定したListBoxで複数選択された項目のValue値を取得したい

Caffellattep

総合スコア12

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

2グッド

1クリップ

投稿2017/10/16 06:38

編集2017/10/16 06:53

visual studio2015 enterprise
windowsフォームアプリケーション
DB:SQLite

色マスタテーブルからデータを取得してリストボックスに表示します。
リストボックスは複数選択可能で、
選択した項目のvalue値を全て取得したいのです。

色マスタテーブル Color id name ---------------------- 001 白 002 黒 003 赤 004 青 005 桃 006 紫
色情報格納クラス class DispItemsDB { public string name { get; set; } public int value { get; set; } } 色データ格納処理 sql = "select value, name color order by value"; List<DispItemsDB> dispItemsDB = new List<DispItemsDB>(); List<object[]> sData = new List<object[]>(); try { //クエリの実行 command.CommandText = sql; using (SQLiteDataReader sdr = command.ExecuteReader()) { List<string[]> tuples = new List<string[]>(); for (int i = 0; sdr.Read(); i++) { string[] column = new string[sdr.FieldCount]; for (int j = 0; j < sdr.FieldCount; j++) { column[j] = sdr[j].ToString(); } sData.Add(column); } //DBを閉じる close(); //リストを配列に変換して返す return sData; } } foreach (object[] a in sData) { var y = new DispItemsDB(); y.value = Convert.ToInt32(a[0]); y.name = (sData[i][1]); dispItemsDB.Add(y); } lstColor.DataSource = dispItemsList; lstColor.DisplayMember = "name"; lstColor.ValueMember = "value";

上記のようにすると、lstColorには

lstColor






と表示されます。

ここで、白、黒、桃を選択した場合に
001,002,005
を取得できるようにしたいのですが、SelectedValueで取得できません。

どうかご教授お願いします。

bochan2, mahry👍を押しています

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2017/10/16 06:46

コードは ``` と ``` で囲ってください。インデントされて見やすくなりますので。
guest

回答2

0

ベストアンサー

例えばですが、下記の様な形で如何でしょうか?

C#

1 //リストを作成 2 List<DispItemsDB> testList = new List<DispItemsDB>(); 3 DispItemsDB DD1 = new DispItemsDB(); 4 DD1.value = 1; 5 DD1.name = "白"; 6 testList.Add(DD1); 7 DispItemsDB DD2 = new DispItemsDB(); 8 DD2.value = 2; 9 DD2.name = "黒"; 10 testList.Add(DD2); 11 DispItemsDB DD3 = new DispItemsDB(); 12 DD3.value = 3; 13 DD3.name = "赤"; 14 testList.Add(DD3); 15 DispItemsDB DD4 = new DispItemsDB(); 16 DD4.value = 4; 17 DD4.name = "青"; 18 testList.Add(DD4); 19 20 //ここでDataSourceを設定 21 listBox1.ValueMember = "value"; 22 listBox1.DisplayMember = "name"; 23 listBox1.DataSource = testList;

で、実際にデータを取り出すところでは…(ここではボタンを押したときに取得したValueをメッセージボックスへ出力させる)

C#

1 private void button1_Click(object sender, EventArgs e) 2 { 3 for (int i = 0; i < listBox1.SelectedItems.Count; i++) 4 { 5 DispItemsDB DD = new DispItemsDB(); 6 DD = (DispItemsDB)listBox1.SelectedItems[i]; 7 MessageBox.Show(DD.value.ToString()); 8 } 9 }

投稿2017/10/16 06:58

motuo

総合スコア3027

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

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

0

sql = "select value, name color order by value";

クエリは正しいですか? from 句が抜けているような気がしますが?

ここで、白、黒、桃を選択した場合に 001, 002, 005 を取得できるようにしたいのですが、SelectedValueで取得できません。

ListBox.SelectedItems プロパティを使って、コントロール内で現在選択されている項目を格納している ListBox.SelectedObjectCollection オブジェクトを取得し、それから value を取得するようにしてはいかがですか?

未検証なのでハズレだったらすみません。

投稿2017/10/16 07:02

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問