从EPPLUS中的文本文件加载日期
本文关键字:文件 加载 日期 文本 EPPLUS | 更新日期: 2023-09-27 18:17:52
我试图在我的web应用程序中创建一个Excel电子表格,使用制表符分隔的文本文件作为数据源。加载数据的代码如下所示:
// Load the data into the cells
Int32 rowIdx = 1;
foreach (String line in tab.Lines)
{
String[] cellTexts = line.Split(TAB);
Int32 colIdx = 1;
foreach (String cellText in cellTexts)
{
sheet.Cells[rowIdx, colIdx].Value = cellText;
colIdx++;
}
rowIdx++;
}
似乎工作得很好。但是,稍后,我在单元格中添加了"mm/dd/yyyy"的NumberFormat:
range.Style.Numberformat.Format = "mm/dd/yyyy";
但是,这不会改变单元格中数据的显示。(日期在原始文本文件中看起来像5/1/15
或12/31/15
,并且在应用格式后保持这种状态。
我很确定这是因为我已经把文本值放入单元格。(虽然看起来像一个日期,但它仍然只是一串字符。)但是从我的阅读,我需要把一个双精度到单元格中,以满足Excel的期望,日期存储为双精度。因为单元格包含字符串而不是双精度类型,所以不应用格式字符串,留下原始的、未格式化的文本。
我想给
添加一些代码- 检查我应用a的范围内每个单元格中的数据类型日期格式。
- 如果不是double类型,尝试转换为日期。
- 如果日期转换成功,则将。net日期转换为OADate并将其放回单元格。
我的问题是:这是最好的(或至少是合理的)方法吗?如果是,我该怎么做?
这段代码不起作用:
foreach (OfficeOpenXml.ExcelRangeBase oneCell in range)
{
if (typeof(oneCell.Value) == "System.String")
{
// date manipulations here
}
}
在typeof(oneCell.Value)
调用的oneCell
下出现红线,提示"无法找到类型或命名空间'oneCell'。"
注意,我不能提前知道日期字段将在哪里,因为数据和单元格格式都是从外部源提供的。(外部单元格格式确实指示应用的格式何时为日期格式,而不是常规数字格式或字符串。)
按照@mason的建议,我把我用来解决这个问题的代码贴出来。
(我没有得到我原来的问题的答案,这是如何在一个范围内迭代单元格并检查每个单元格内容的数据类型,但有了这个解决方案,我不再需要这样做。)
相反,我修改了从制表符分隔的文本文件加载数据的循环,以便使用一些TryParse()
调用来检测日期、数字或常规文本数据,然后将适当类型的数据加载到单元格中。请注意,如果单元格实际上是文本,但看起来像数字或日期,它是如何检查前导单引号字符以抑制数据键入的:
// Load the data into the cells
Int32 rowIdx = 1;
foreach (String line in tab.Lines)
{
String[] cellTexts = line.Split(TAB);
Int32 colIdx = 1;
foreach (String cellText in cellTexts)
{
DateTime dateValue;
Double doubleValue;
if(cellText.StartsWith("'"))
{
sheet.Cells[rowIdx, colIdx].Value = cellText.Substring(1);
}
else if(DateTime.TryParse(cellText,out dateValue))
{
sheet.Cells[rowIdx, colIdx].Value = dateValue;
}
else if (Double.TryParse(cellText, out doubleValue))
{
sheet.Cells[rowIdx, colIdx].Value = doubleValue;
}
else
{
sheet.Cells[rowIdx, colIdx].Value = cellText;
}
colIdx++;
}
rowIdx++;
}
在单元格中输入适当的数据,格式就会达到预期的效果。