具有EPPlus解析问题的CSV

本文关键字:CSV 问题 EPPlus 具有 | 更新日期: 2023-09-27 18:15:57

我正在使用EPPlus读取数据。该数据由.xlsx.csv组成。

当文件是.csv文件时,我使用LoadFromText功能。但是EPPlus决定它还必须解析它不应该解析的所有值

例如:

Id;Double;
1;-3,88;
ExcelTextFormat format = new ExcelTextFormat();
format.Delimiter = ';';
worksheet.Cells[1, 1].LoadFromText( "file", format );

结果是工作表中的-3,88值变为:-388。我发现这是因为EPPlus将-3,88视为一个数字,并将其解析为默认区域性为InvariantCulture的数字,在这种情况下是(类似于)us-US

如何实现EPPlus加载csv不解析?

具有EPPlus解析问题的CSV

似乎EPPlus总是用en-US格式解析导入的数据。因此,首先将包含十进制值的列导入为字符串。这样就不会试图进行转换。

ExcelTextFormat format = new ExcelTextFormat
{
    Delimiter = ';',
    DataTypes = new eDataTypes[] { eDataTypes.Number, eDataTypes.String }
};

在为您的本地化使用正确的十进制分隔符导入值之后,循环这些值,将它们转换为十进制并设置正确的数字格式。

int columnNumber = 2;
for (int i = 2; i <= rowCount; i++)
{
    worksheet.Cells[i, columnNumber].Style.Numberformat.Format = "0.00";
    worksheet.Cells[i, columnNumber].Value = Convert.ToDecimal(worksheet.Cells[i, columnNumber].Value);
}