次のようなデータテーブルがあります。
Data Value 1 Value 2 Value 3
series1 32 -2 46
series2 -62 99
series3 19 23 98
チャートでは、次のようにする必要があります。
32 -2 46 -62 99 19 23 98
series1 series2 series3
および凡例: 値 1、値 2、値 3
私が試したコード:
private void LoadChartCurrencyTotal(DataTable initialDataSource)
{
DataTable pivotedDt = Pivot(initialDataSource);
chart1.DataSource = pivotedDt;
foreach (DataRow dr in pivotedDt.Rows)
{
Series series = new Series(dr["Data"].ToString());
List<string> colNames = (from DataColumn col in pivotedDt.Columns where col.ColumnName != "Data" select col.ColumnName).ToList();
series.XValueMember = "Data";
series.YValueMembers = string.Join(",", colNames);
chart1.Series.Add(series);
}
chart1.DataBind();
FormatChart(chart1);
}
Data points insertion error. Only 1 Y values can be set for this data series.
これは、列名が結合されているために返されます。
また試しました:
private void LoadChartCurrencyTotal(DataTable initialDataSource)
{
DataTable pivotedDt = Pivot(initialDataSource);
foreach (DataRow pivotDr in pivotedDt.Rows)
{
Series serie = new Series(pivotDr["Data"].ToString());
List<decimal?> colValues = new List<decimal?>();
foreach (DataColumn col in pivotedDt.Columns)
{
if (col.ColumnName != "Data")
{
//colValues.Add(pivotDr[col.ColumnName] != DBNull.Value
// ? decimal.Parse(pivotDr[col.ColumnName].ToString())
// : new decimal?());
decimal? colValue = pivotDr[col.ColumnName] != DBNull.Value
? decimal.Parse(pivotDr[col.ColumnName].ToString())
: new decimal?();
serie.Points.AddXY(pivotDr["Data"], colValue);
}
}
//serie.Points.AddXY(pivotDr["Data"], string.Join(",", colValues));
chart1.Series.Add(serie);
}
FormatChart(chart1);
}
これはコンパイルされますが、結果は完全に台無しです: 凡例は series1、series2、series3 であり、結果は次のとおりです。
32 -62 19 -2 23 46 99 98
series1 series2 series3
行ごとではなく、列ごとに結果を取得します。
そして、私が最後に試したのは次のとおりです。
DataView pivotedDv = pivotedDt.AsDataView();
chart1.DataBindTable(pivotedDv, pivotedDt.Columns[0].ColumnName);
しかし、これは以下のみを返します:
0.00 0.00 0.00
series1 series2 series3
凡例: 0.00
これがどのように達成されるべきか、誰かが手がかりを持っていることを願っています。ただし、ドラッグ アンド ドロップ アンド クリックのソリューションではなく、コーディングしてください。ありがとう