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

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

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

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

Q&A

解決済

1回答

14651閲覧

【C#】DataTableをDistinctしたい。

miyamoto0105

総合スコア216

C#

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

0グッド

0クリップ

投稿2015/08/26 14:04

編集2015/08/27 01:30

dtの列はA~Eまでとする。


A B C D E

1 1 a a a
1 2 a a a
2 2 a a b
2 2 a a c

AとBの列だけDistinctしてA~Eまで表示したい。

A B C D E

1 1 a a a
1 2 a a a
2 2 a a b

DataView dv = dt.DefaultView;
DataTable dtdistinct = dv.ToTable("dt", true, "A", "B");
このように書くとAとBだけしか表示できないし、
なんかもっといい書き方が出来るような気がしています。

DataTable dt = new DataTable();
dt.AsEnumerable().Select(row => row.Field<int>("A列", "B列")).Distinct()
見ないな感じで、うまく書く方法を御存知の方いらっしゃいますでしょうか。

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

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

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

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

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

yuba

2015/08/26 14:21

> AとBの列だけDistinctしてA~Eまで表示したい。 ということは、表示結果がどんな姿になることを期待しているのでしょうか?
miyamoto0105

2015/08/27 01:30 編集

わかりにくてすいません。
guest

回答1

0

ベストアンサー

冗長にはなってしまいますがIEqualityComparer実装してDistinctで実現可能です。

csharp

1class DataRowEqualityComparer : IEqualityComparer<DataRow> 2{ 3 4 public bool Equals(DataRow dr1, DataRow dr2) 5 { 6 return dr1["A"].ToString() == dr2["A"].ToString() 7 && dr1["B"].ToString() == dr2["B"].ToString(); 8 } 9 10 11 public int GetHashCode(DataRow dr) 12 { 13 string hCode = dr["A"].ToString() +"|"+ dr["B"].ToString(); 14 return hCode.GetHashCode(); 15 } 16 17}

使い方は

cshrap

1var row = dt.AsEnumerable().Distinct(new DataRowEqualityComparer());

ただし今どきDataTableを使うメリットは皆無なのできちんとカスタムクラスを作る等した方がいいでしょう。
以下のようなライブラリを使う(または実装する)前提ですが匿名型で処理するのもありです。
AnonymousComparer - lambda compare selector for Linq

投稿2015/08/26 15:39

sho_cs

総合スコア3541

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

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

miyamoto0105

2015/08/27 01:29

解決しました!!!ありがとうございます!!!
miyamoto0105

2015/08/27 02:22

すいません。書いてある問題は解決したのですが、意味がわかってません。今はAとB列でDistinctして残りの列C~Eは片一方のほうがでているのですが、ここを違うほうを出したり制御はできるのでしょうか。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問