Trying to add the currency symbol to value using system.globalization
i am trying to add the currency symbol to totalvalue by using following code
using System.Globalization;
double value;
double totalValue = 0.0;
foreach (DataRow row in reportData.Rows)
{
if (double.TryParse(row["value"].ToString(), out value))
{
totalValue += value;
RegionInfo rgi = new RegionInfo("en-UK");
totalValue += Convert.ToString(string.Format(" CurrencySymbol: {0}\n", rgi.CurrencySymbol));
}
}
it was giving error can not convert type string
to double
would any one pls help me
Modified CODE:
int count;
int total = 0;
double value;
double totalValue = 0.0;
foreach (DataRow row in reportData.Rows)
{
if (double.TryParse(row["value"].ToString(), out value))
{
totalValue += value;
}
if (!Overview && int.TryParse(row["mshipssold"].ToString(), out count))
{
total += count;
}
}
DataRow 开发者_如何学PythontotalRow = reportData.NewRow();
totalRow["mshipType_Name"] = "Total";
totalRow["mshipssold"] = total;
totalRow["value"] = totalValue;
reportData.Rows.Add(totalRow);
targetChartControl.Series["Value"].Points.DataBindXY(reportData.Rows, "mshipType_Name", reportData.Rows, "value");
if (!Overview)
{
targetChartControl.Series["Quantity"].Points.DataBindXY(reportData.Rows, "mshipType_Name", reportData.Rows, "mshipssold");
}
}
Modified code :1
graph
I want to show like this £3830 , £2070 , £5090 on the blue bars
and this is my code
try
{
DataTable reportData = KPIData.MembershipSales(StartDate, EndDate, mf);
Series quantitySeries;
Series valueSeries = null;
Title title;
string area;
targetChartControl.ChartAreas.Clear();
targetChartControl.Series.Clear();
targetChartControl.Titles.Clear();
area = "Value";
targetChartControl.ChartAreas.Add(area);
quantitySeries = targetChartControl.Series.Add(area);
quantitySeries.ChartArea = area;
if (!Overview)
{
title = targetChartControl.Titles.Add("Membership Sales by Total Contract Value by Type");
title.Font = new Font(FontFamily.GenericSansSerif, 10, FontStyle.Bold);
title.Alignment = ContentAlignment.TopLeft;
title.DockedToChartArea = area;
targetChartControl.Titles.Add("").DockedToChartArea = area;
}
targetChartControl.Titles.Add("Membership sale values").DockedToChartArea = area;
if (!Overview)
{
area = "Quantity";
targetChartControl.ChartAreas.Add(area);
quantitySeries = targetChartControl.Series.Add(area);
quantitySeries.ChartArea = area;
title = targetChartControl.Titles.Add("Membership Sales by Quantity");
title.Font = new Font(FontFamily.GenericSansSerif, 10, FontStyle.Bold);
title.Alignment = ContentAlignment.TopLeft;
title.DockedToChartArea = area;
targetChartControl.Titles.Add("").DockedToChartArea = area;
targetChartControl.Titles.Add("Membership sale quantities").DockedToChartArea = area;
}
foreach (Title chartTitle in targetChartControl.Titles)
{
chartTitle.IsDockedInsideChartArea = false;
}
foreach (ChartArea chartArea in targetChartControl.ChartAreas)
{
chartArea.Area3DStyle.Enable3D = true;
chartArea.AxisX.LabelStyle.IsEndLabelVisible = true;
}
foreach (Series series in targetChartControl.Series)
{
series.ChartType = SeriesChartType.StackedColumn;
series["ColumnDrawingStyle"] = "SoftEdge";
series["LabelStyle"] = "Top";
series.IsValueShownAsLabel = true;
// series.CustomProperties = "DrawingStyle=Cylinder";
series.BackGradientStyle = GradientStyle.DiagonalLeft;
}
foreach (Legend legend in targetChartControl.Legends)
{
legend.Enabled = false;
}
if (reportData == null)
{
valueSeries.Points.Clear();
valueSeries.Points.AddXY("No sales for this time period", 0);
if (!Overview)
{
quantitySeries.Points.Clear();
quantitySeries.Points.AddXY("No sales for this time period", 0);
}
}
else
{
int count;
int total = 0;
double value;
double totalValue = 0.0;
foreach (DataRow row in reportData.Rows)
{
if (double.TryParse(row["value"].ToString(), out value))
{
totalValue += value;
}
if (!Overview && int.TryParse(row["mshipssold"].ToString(), out count))
{
total += count;
}
}
CultureInfo rgi = new CultureInfo("en-GB");
string totalcurrency = string.Format(rgi, "{0:C}", totalValue);
DataRow totalRow = reportData.NewRow();
totalRow["mshipType_Name"] = "Total";
totalRow["mshipssold"] = total;
totalRow["value"] = totalcurrency;
reportData.Rows.Add(totalRow);
targetChartControl.Series["Value"].Points.DataBindXY(reportData.Rows, "mshipType_Name", reportData.Rows, "value");
if (!Overview)
{
targetChartControl.Series["Quantity"].Points.DataBindXY(reportData.Rows, "mshipType_Name", reportData.Rows, "mshipssold");
}
}
}
catch
{
}
You need to do your totalling and then convert it to a string.
double totalValue;
foreach (DataRow row in reportData.Rows) {
double value;
if (double.TryParse(row["value"].ToString(),out value) totalValue+= value;
}
CultureInfo rgi = new CultureInfo("en-GB");
string totalValueCurrency=string.Format(rgi,"{0:c}", totalValue);
In answer to your modified question:
before before DataRow totalRow = reportData.NewRow();
insert the two lines
CultureInfo rgi = new CultureInfo("en-GB");
string totalValueCurrency=string.Format(rgi,"{0:c}", totalValue);
and then change
totalRow["value"] = totalValue;
to read
totalRow["value"] = totalValueCurrency;
However this might go horribly wrong if the datatype of your column is not string. You may be better of changing your report to do the formatting for you.
If you are using Microsoft Chart Control you may want this instead:
Modify this section of code
foreach (ChartArea chartArea in targetChartControl.ChartAreas) {
chartArea.Area3DStyle.Enable3D = true;
chartArea.AxisX.LabelStyle.IsEndLabelVisible = true;
// New Line Here
chartArea.AxisY.LabelStyle.Format = "C";
}
You cannot store a string in a double - this will never work when totalValue is a double.
totalValue += Convert.ToString(string.Format(" CurrencySymbol: {0}\n", rgi.CurrencySymbol));
This line is a bit confused:
totalValue += Convert.ToString(string.Format(" CurrencySymbol: {0}\n", rgi.CurrencySymbol));
totalValue
is a double and you're trying to add a string to it.
精彩评论