gpt4 book ai didi

c# - 将存储为文本的数字转换为数字

转载 作者:太空狗 更新时间:2023-10-29 21:21:21 35 4
gpt4 key购买 nike

我有一个 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# 中执行哪些操作才能转换存储为文本的数字列。

最佳答案

将单元格值转换为 .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());
}

enter image description here

关于c# - 将存储为文本的数字转换为数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42240449/

35 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com