具有 EPPlus 解析问题的 CSV
CSV with EPPlus parsing issues
我正在使用 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);
}
我正在使用 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);
}