it-swarm.com.de

Als Text gespeicherte Zahl in Zahl konvertieren

Ich habe eine Excel-Arbeitsmappe, in der Spalte C als Nummer als Text gespeichert ist. Wie lautet die C # -Syntax, um sie in eine Zahl umzuwandeln? Ich weiß, dass diese VBA den Job machen wird

Range("C:C").Select
With Selection
    Selection.NumberFormat = "0.00%"
    .Value = .Value
End With

Und ich habe es mit C # versucht - aber es hat die Zahlen als Text gespeichert.

ExcelWorksheet ws3 = pck.Workbook.Worksheets.Add("New Sheet");
ws3.Cells["A1"].LoadFromDataTable(tableforme, true);
ws3.View.FreezePanes(2, 4);
ws3.Cells["C:C"].Style.Numberformat.Format = "#,##0.00";
ws3.Cells["C:C"].Style.Numberformat.Format = "0%";

Was muss ich in C # tun, um eine Spalte zu konvertieren, die Zahlen enthält, die als Text gespeichert sind?.

5
Yohan Greenburg

Das Konvertieren der Zellwerte in den .NET-Typ funktioniert bei mir:

var values = new List<object[]>()
{ 
    new string[] { "0.001", "1.001", "2.002" }, 
    new string[] { "3.003", "4.004", "5.005" },
    new string[] { "6.006", "7.007", "8.008" }
};

using (var package = new ExcelPackage())
{
    var sheet = package.Workbook.Worksheets.Add("Sheet1");
    sheet.Cells["A1"].LoadFromArrays(values);
    foreach (var cell in sheet.Cells["C:C"])
    {
        cell.Value = Convert.ToDecimal(cell.Value);
    }
    sheet.Cells["C:C"].Style.Numberformat.Format = "#,##0.00";
    File.WriteAllBytes(OUTPUT, package.GetAsByteArray());
}

 enter image description here

3
kuujinbo

Ich verstehe nicht, was Kuujinbo mit all dem Paketmaterial macht. Es ist viel einfacher, dasselbe wie mit VB zu tun:

using Excel = Microsoft.Office.Interop.Excel;

...

Excel.Range rangeOfValues = ws3.Range("C:C");
rangeOfValues.Cells.NumberFormat = "#0";
rangeOfValues.Value = rangeOfValues.Value;
1
TheAtomicOption

Haben Sie versucht, 'w3.Columns.NumberFormat' anstelle von 'Cells []. Style.NumberFormat.Format' zu verwenden?

Es ist das, was ich an einigen Stellen in einer Excel VSTO-App verwende und es funktioniert großartig.

0
therea1wags