我正在使用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总是解析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);
}

关于c# - CSV与EPPlus解析问题,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/40360112/

10-10 18:56