【问题标题】:Convert Number Stored As Text To Number将存储为文本的数字转换为数字
【发布时间】:2017-02-15 03:56:37
【问题描述】:

我有一个 Excel 工作簿,其中 C 列作为数字存储为文本。将其转换为数字的 C# 语法是什么?我知道这个 VBA 可以完成这项工作

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

我用 C# 尝试过这个 - 但它留下了以文本形式存储的数字。

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%";

我必须在 C# 中做什么来转换存储为文本的数字列。

【问题讨论】:

    标签: c# excel c#-4.0 vsto epplus


    【解决方案1】:

    将单元格值转换为 .NET 类型对我有用:

    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());
    }
    

    【讨论】:

    • 代码适用于小数字值,您能建议如何将 16 位从科学值转换为文本吗?
    【解决方案2】:

    我不明白 kuujinbo 对所有这些包裹的东西做了什么。 用 VB 做同样的事情要简单得多:

    using Excel = Microsoft.Office.Interop.Excel;
    
    ...
    
    Excel.Range rangeOfValues = ws3.Range("C:C");
    rangeOfValues.Cells.NumberFormat = "#0";
    rangeOfValues.Value = rangeOfValues.Value;
    

    【讨论】:

      【解决方案3】:

      您是否尝试过使用 'w3.Columns.NumberFormat' 代替 'Cells[].Style.NumberFormat.Format'

      这是我在 Excel VSTO 应用程序的几个地方使用的,效果很好。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多