我有A行B列的EXCEL表格:
获取一行数据:
IRow row=sheet.GetRow(i);
正常是这样的
row.Cells.Count = B;
但由于会存在没有激活的单元格,导致 row.Cells.Count <=B。
坑是这样的:
当你想要对某行第2个(或其他)单元格进行赋值时,我是这样做了:
row.Cells[1].SetCellValue("######");
如果恰巧这行的所有单元格都是激活的,那这样做的结果是没错的。
但如果刚好第2个单元格(你想的)没有被激活过,这将导致第2个激活的单元格(具体哪个不确定)被覆盖。
正确做法:
//真正的第2个单元格
public ICell GetCell(int index)
{
ICell cell = this.Row.FirstOrDefault(n => n.ColumnIndex == index);
if (cell == null)
{
cell = this.Row.CreateCell(index);
}
return cell;
}
这样就保证第2个单元格被赋值,而不覆盖其它的。
碰到连续空单元格会导致数据列错乱,用以下方法解决
rw.GetCells().Select(R=>R.ToString()).ToArray()