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

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

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

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

DataGrid

GUIの一種であり、データを表の形式でみることが可能です。

Visual Studio

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

XAML

XAML(Extensible Application Markup Language)はWPF、Silverlight、Windows PhoneそしてWindows Store appsでユーザーインターフェースを定義するために使われるXML言語です。

WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

Q&A

解決済

1回答

1182閲覧

WPF CsvHelperがDataGridに表示されない

MARINE_SeaDevil

総合スコア4

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

DataGrid

GUIの一種であり、データを表の形式でみることが可能です。

Visual Studio

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

XAML

XAML(Extensible Application Markup Language)はWPF、Silverlight、Windows PhoneそしてWindows Store appsでユーザーインターフェースを定義するために使われるXML言語です。

WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

0グッド

0クリップ

投稿2020/06/05 10:16

編集2020/06/06 03:58

以下のコードを書いてビルドしてみたのですが、CSVファイルが読み込まず、表示されません。
どこがいけないのでしょうか。また何を追加すればいいのでしょうか。

C#

1 OpenFileDialog ofd = new OpenFileDialog(); 2 { 3 4 if(ofd.ShowDialog() == true) 5 { 6 ofd.Filter = "csv ファイル(*.csv)|*.csv"; 7 ofd.Title = "CSVファイルを開く"; 8 9 var sr = new StreamReader(ofd.FileName , Encoding.GetEncoding("SHIFT-JIS")); 10 var csv = new CsvHelper.CsvReader(sr , new System.Globalization.CultureInfo("ja-JP", false)); 11 { 12 csv.Configuration.HasHeaderRecord = true; 13 csv.Configuration.Delimiter = ","; 14 csv.Configuration.IgnoreBlankLines = true; 15 csv.Configuration.DetectColumnCountChanges = true; 16 csv.Configuration.BadDataFound = x => 17 dataGrid.ItemsSource = csv.GetRecords<DataBind>().ToList(); 18 } 19 20 21 } 22 23 } 24 } 25 public class DataBind 26 { 27 28 [Index(0)] 29 public string Title { get; set; } 30 [Index(1)] 31 public string Title_read { get; set; } 32 [Index(2)] 33 public string Price { get; set; } 34 [Index(3)] 35 public string Category { get; set; } 36 [Index(4)] 37 public string Stock_img { get; set; } 38 [Index(5)] 39 public string Sub_img1 { get; set; } 40 [Index(6)] 41 public string Sub_img2 { get; set; } 42 [Index(7)] 43 public string Sub_img3 { get; set; } 44 [Index(8)] 45 public string Sub_img4 { get; set; } 46 [Index(9)] 47 public string Sub_img5 { get; set; } 48 }

XAML

1 <DataGrid Name="dataGrid" AutoGenerateColumns="False" Height="500"> 2 <DataGrid.Columns> 3 <DataGridTextColumn Binding="{Binding Title}" Header="タイトル"/> 4 <DataGridTextColumn Binding="{Binding Price}" Header="価格"/> 5 </DataGrid.Columns> 6 </DataGrid>

Visual Studio2019
ver 16.6.1
.NET Framework
ver 4.8.03752

CSVの内容が書かれていませんでしたので、追記いたします。
※テスト用です。

CSV

1書名,書名よみ,税込価格,在庫カテゴリ,在庫画像,サブ画像1,サブ画像2,サブ画像3,サブ画像4,サブ画像5 2あああaaa,あああaaa,100,1,aaa,bbb,ccc,ddd,eee,fff,ggg 3いいいbbb, ,1000,2,hhh, , , , , , 4. 5. 6.

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

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

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

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

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

guest

回答1

0

ベストアンサー

下記箇所がラムダ式になっています。
BadDataFoundの行を削除してみてはいかがでしょうか。

C#

1csv.Configuration.BadDataFound = x => 2dataGrid.ItemsSource = csv.GetRecords<DataBind>().ToList();

投稿2020/06/05 10:38

takapi_cs

総合スコア349

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

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

MARINE_SeaDevil

2020/06/05 12:30

BadDataFoundの行を削除してみましたが、 [外部コード]でスローされました と表示され動作が止まってしまいます。
takapi_cs

2020/06/05 14:17

下記のようにusingを使ってみてください。 あなたの環境でも、例外が発生するところがわかると思います。 using(var sr = new StreamReader(ofd.FileName , Encoding.GetEncoding("SHIFT-JIS"))) using(var csv = new CsvHelper.CsvReader(sr , new System.Globalization.CultureInfo("ja-JP", false))) { } ちなみに、私の環境では、下記のエラーメッセージが表示されました。 System.ArgumentException: ''SHIFT_JIS' is not a supported encoding name. For information on defining a custom encoding, see the documentation for the Encoding.RegisterProvider method. ' あとは下記のサイトを参考にしてみてください。 http://akira-arets.blogspot.com/2017/09/dotnetcore2-csvhelper-shiftjis.html
TN8001

2020/06/05 15:10

.NET FrameworkですからSHIFT-JISは問題無いです。 CSVが不正なのでは? わざわざ厳しい設定をしていますが、わかって書いているのかが不明ですね。
takapi_cs

2020/06/05 22:30

>.NET FrameworkですからSHIFT-JISは問題無いです。 私の環境は.NET Coreで作ってました。 .NET Frameworkで再確認したところ、''SHIFT_JIS' is not a supported encoding name. ...云々のエラーはありませんでした。 失礼しました。 使用しているCSVが気になりますね。
Zuishin

2020/06/06 04:47

とりあえず質問に掲載されている CSV はフィールドの数が行によってまちまちというひどいものですね。
takapi_cs

2020/06/06 10:07

テスト用csvで実行したところ、下記エラーが出ています。 CsvHelper.BadDataException: 'An inconsistent number of columns has been detected.' どうやらDetectColumnCountChangesの設定がtrueになっているので、上記エラーが検出されるようです。 他の設定も改めて確認してみては。 https://tomisenblog.com/c-sharp-csvhelper/#outline_1__2_3
MARINE_SeaDevil

2020/06/07 06:44

csv.Configuration.HasHeaderRecord をtrueにしているので 格納用クラス[index()]を[Name("")]に変えることで読むことが 可能になりました。 しかしその場合小文字「a」が認識してくれません。 その場合はGetEncodingまたはCultureInfoを どのようにすればよろしいでしょうか。
takapi_cs

2020/06/07 07:52

GetEncoding、CultureInfoは記載されているものを使用していますが、問題ありませんでした。 私の環境では、前回回答時点でDetectColumnCountChanges=falseにすることで、ヘッダとデータのカラム数の不整合エラーにならず読み込めました。 その際、格納用クラスのプロパティ属性には[index()]を使用していました。 属性を[Name("")]に変更したことにより、別の不具合を作っていませんか? csvファイルのフォーマットについても、改めて確認しますが、現在下記状態ですがこれは仕様でしょうか? ヘッダ→カラム数10 データ→カラム数11
MARINE_SeaDevil

2020/06/07 10:24

カラム数は間違えてしまいました、すみません。 直してみてやってみたら、 CsvHelper.TypeConversion.TypeConverterException HResult=0x80131500 Message=The conversion cannot be performed. Text: 'a' MemberType: System.Int32 TypeConverter: 'CsvHelper.TypeConversion.Int32Converter' このように出ました。
Zuishin

2020/06/07 10:26

DataBind の型まで違うとは。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問