将存储为文本的数字转换为数字
Convert Number Stored As Text To Number
我有一个 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# 中执行什么操作才能将数字列转换为文本。
您尝试过使用
'w3.Columns.NumberFormat'
代替
'Cells[].Style.NumberFormat.Format'
这是我在 Excel VSTO 应用的几个地方使用的东西,效果很好。
将单元格值转换为 .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());
}
我不明白 kuujinbo 对那些包里的东西做了什么。
用 VB:
做同样的事情要简单得多
using Excel = Microsoft.Office.Interop.Excel;
...
Excel.Range rangeOfValues = ws3.Range("C:C");
rangeOfValues.Cells.NumberFormat = "#0";
rangeOfValues.Value = rangeOfValues.Value;
我有一个 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# 中执行什么操作才能将数字列转换为文本。
您尝试过使用 'w3.Columns.NumberFormat' 代替 'Cells[].Style.NumberFormat.Format'
这是我在 Excel VSTO 应用的几个地方使用的东西,效果很好。
将单元格值转换为 .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());
}
我不明白 kuujinbo 对那些包里的东西做了什么。 用 VB:
做同样的事情要简单得多using Excel = Microsoft.Office.Interop.Excel;
...
Excel.Range rangeOfValues = ws3.Range("C:C");
rangeOfValues.Cells.NumberFormat = "#0";
rangeOfValues.Value = rangeOfValues.Value;