私は非常に奇妙な問題を抱えています:
Excelを読むためにNPOI ngetパッケージを使用し、私のコードは
HttpPostedFileBase file = Request.Files[0];
string fileName = file.FileName;
Stream filestream = file.InputStream;
string fileExtension = System.IO.Path.GetExtension(Request.Files[0].FileName);
if (fileExtension == ".xls" || fileExtension == ".xlsx")
{
HSSFWorkbook hssfwb;
hssfwb= new HSSFWorkbook(filestream);
ISheet sheet = hssfwb.GetSheetAt(0);
for (int row = 1; row <= sheet.LastRowNum; row++)
{
if (sheet.GetRow(row) != null) //null is when the row only contains empty cells
{
Cordinates cord = new Cordinates();
cord.x =sheet.GetRow(row).GetCell(1).StringCellValue;
cord.y = sheet.GetRow(row).GetCell(2).ToString();
cord.h = sheet.GetRow(row).GetCell(3).ToString();
lstCordinatestoReturn.Add(cord);
}
}
SO最も奇妙なことは、セルの値がこの 123,233 13,333 (数字とコンマのみ) であり、セルがテキストセルとしてフォーマットされていても、常にドットで値を取得することです
cord.y = sheet.GetRow(row).GetCell(2).ToString(); // theresult will ve 123.2333
そして最初のものでさえ例外を与えています()
cord.x =sheet.GetRow(row).GetCell(1).StringCellValue; // gives an exception : Cannot get a text value from a numeric cell