我正在从 List<object[]>
创建电子表格使用 LoadFromArrays
数组的第一个条目是标题,其他条目可能是数字、文本或日期(但列表中的每个数组都相同)。
生成的 Excel 工作表带有绿色三角形警告,表示数字已格式化为文本。
我遍历所有单元格并将它们的格式设置为 Number,就像这样 ws.Cells[i, j].Style.Numberformat.Format = "0";
但是问题仍然存在,我仍然看到绿色警告,即使当我查看 Format Cell...
时数字格式设置为数字也是如此。对话。
我在这里有哪些选择?我有可能更多地了解每列中的类型,但我该如何设置列标题?
有比 EPPlus 更好的解决方案吗?或者我可以在下载之前对电子表格进行更多后期处理?
最佳答案
由于您使用的是对象数组,它们可以包含数字和看起来像数字的字符串,因此您必须遍历每个对象并确定其类型:
[TestMethod]
public void Object_Type_Write_Test()
{
//http://stackoverflow.com/questions/31537981/using-epplus-how-can-i-generate-a-spreadsheet-where-numbers-are-numbers-not-text
var existingFile = new FileInfo(@"c:\temp\temp.xlsx");
if (existingFile.Exists)
existingFile.Delete();
//Some data
var list = new List<Object[]>
{
new object[]
{
"111.11",
111.11,
DateTime.Now
}
};
using (var package = new ExcelPackage(existingFile))
{
var ws = package.Workbook.Worksheets.Add("Sheet1");
ws.Cells[1, 1, 2, 2].Style.Numberformat.Format = "0";
ws.Cells[1, 3, 2, 3].Style.Numberformat.Format = "[$-F400]h:mm:ss\\ AM/PM";
//This will cause numbers in string to be stored as string in excel regardless of cell format
ws.Cells["A1"].LoadFromArrays(list);
//Have to go through the objects to deal with numbers as strings
for (var i = 0; i < list.Count; i++)
{
for (var j = 0; j < list[i].Count(); j++)
{
if (list[i][j] is string)
ws.Cells[i + 2, j + 1].Value = Double.Parse((string) list[i][j]);
else if (list[i][j] is double)
ws.Cells[i + 2, j + 1].Value = (double)list[i][j];
else
ws.Cells[i + 2, j + 1].Value = list[i][j];
}
}
package.Save();
}
}
通过上面的代码,您会看到下图作为输出 注意左上角带有绿色箭头的单元格,因为它是由 LoadFromArray
编写的字符串,看起来像一个数字:
关于c# - 使用 EPPlus 如何生成电子表格,其中数字是数字而不是文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31537981/