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

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

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

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

Q&A

解決済

1回答

235閲覧

C# chartグラフの動的作成

goldman99

総合スコア1

C#

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

1グッド

0クリップ

投稿2024/11/14 05:05

実現したいこと

C#のchart機能でグラフを作成中。
seriesを動的に追加したい。

発生している問題・分からないこと

テキストデータを投入してDataGridViewで表にする。そしてその表を参照してchartで折れ線グラフを作成。
ということをやっているのですが、投入データによってDataGridViewの列の数が違うためグラフの線を何本出すかが未定となります。

現状、使う分だけあらかじめ手動でseriesを作っているのですが、投入したデータに応じて動的にchart.series.addを行うように変更したいです。

該当のソースコード

特になし

試したこと・調べたこと

  • teratailやGoogle等で検索した
  • ソースコードを自分なりに変更した
  • 知人に聞いた
  • その他
上記の詳細・結果

一個のseriesの中身を変更して実現できないか試したが、addする際に「この名前のseriesは既にあります」というエラーになってしまう。

補足

特になし

TN8001👍を押しています

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

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

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

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

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

YAmaGNZ

2024/11/14 05:39

現在どのようなコードで行っているのですか?
goldman99

2024/11/14 06:29

DataGridViewの1列を1本の折れ線グラフにしています。 DataGridViewのcolumn数確認 ↓ column数分、chartにseries追加 ↓ series.Points.AddXYでchartにデータ反映 という風にしています。 都合により実際のコード載せられずすみません。
YAmaGNZ

2024/11/14 07:47

もしかして「一個のseriesの中身を変更して」ということは 一度 Series series = new Series(); という感じでSeriesを作成した後に 列毎にそのプロパティ部分を変更しaddした後、次の列用にプロパティを変更してaddするといった処理を作成されているのでしょうか? そうなのであれば列毎にSeriesクラスを生成するように変更すればいいのではないかと思います。 上記のような処理ではないのであれば実際に作成しているコードをそのまま載せるのではなく現象が再現できる最低限のコードを提示してください。
guest

回答1

0

ベストアンサー

テキストデータを投入してDataGridViewで表にする。そしてその表を参照してchartで折れ線グラフを作成。

どのように読み込んでいるかが不明ですが、DataTableを使ってもいいですか?

DataGridViewの1列を1本の折れ線グラフにしています。

値がXになるのかYになるのかわかりませんが、もうひとつデータが必要ではありませんか?

cs

1using System; 2using System.Data; 3using System.Linq; 4using System.Windows.Forms; 5using System.Windows.Forms.DataVisualization.Charting; 6 7namespace Q8q6v81jc43auy3 8{ 9 public partial class Form1 : Form 10 { 11 public Form1() => InitializeComponent(); 12 13 private void Button1_Click(object sender, EventArgs e) 14 { 15 var dt = new DataTable(); 16 var r = new Random(); 17 var c = r.Next(1, 8); // カラム数 18 19 // DataTableの最初のカラムは行番号的な連番(DataGridViewでは非表示) 20 dt.Columns.Add("XValue").ColumnMapping = MappingType.Hidden; 21 22 // カラムをランダム個追加 23 for (var i = 0; i < c; i++) dt.Columns.Add(); 24 25 // とりあえず10行追加 26 for (var i = 0; i < 10; i++) 27 { 28 // テキトウなデータ 29 var values = Enumerable.Repeat(0, c).Select(_ => (object)r.Next(0, 100)); 30 31 // データの先頭に行番号追加 32 dt.Rows.Add(values.Prepend(i).ToArray()); 33 } 34 dataGridView1.DataSource = dt; 35 36 37 chart1.Series.Clear(); 38 39 // 先頭は行番号なのでスキップ 40 foreach (var col in dt.Columns.Cast<DataColumn>().Skip(1)) 41 { 42 var series = chart1.Series.Add(col.ColumnName); 43 series.ChartType = SeriesChartType.Line; 44 series.XValueMember = "XValue"; // Xを行番号に割り当て 45 series.YValueMembers = col.ColumnName; 46 } 47 chart1.DataSource = dt; 48 } 49 } 50}

アプリ動画

投稿2024/11/14 10:07

TN8001

総合スコア9801

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

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

goldman99

2024/11/21 08:05

ありがとうございます。解決できました。 X軸Y軸は値と時間で作成していました。 恐らくDataGridViewを直接触っていたのが原因で、dtを触った後データソースにすることで解決できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問