想不明白怎么解决的鱼 2022-04-11 10:21 采纳率: 53.3%
浏览 29
已结题

C#:应该怎么赋值才行?

运行时候老是提示未将对象引用到设置到对象实例中,应该怎么处理才对?
DataTable dt = new DataTable( FilePath);
FileStream fs = new FileStream("", FileMode.Open, FileAccess.Read);

        NPOI.XSSF.UserModel.XSSFWorkbook book = new NPOI.XSSF.UserModel.XSSFWorkbook(fs);
        //是否找到表头
        bool isTitle = false;
        NPOI.SS.UserModel.ISheet sheet = book.GetSheetAt(0);
        for (int i = 0; i <= sheet.LastRowNum; i++)
        {
            NPOI.SS.UserModel.IRow row = sheet.GetRow(i);
            if (row.GetCell(0).ToString() == "INVOICENO")
            {
                //表头行
                isTitle = true;
                if (row == null) continue;
                int firstCellNum = row.FirstCellNum;
                int lastCellNum = row.LastCellNum;
                if (firstCellNum == lastCellNum) continue;

                for (int ji = firstCellNum; ji < lastCellNum; ji++)
                {
                    if (!dt.Columns.Contains(row.GetCell(ji).ToString()))
                    {
                        dt.Columns.Add(row.GetCell(ji).StringCellValue, typeof(string));
                    }
                }
            }

            if (isTitle)
            {
                //其它行
                DataRow newRow = dt.Rows.Add();
                for (int j = 0; j < 14; j++)
                {
                    newRow[j] = row.GetCell(j).ToString();
                }
            }
        }
  • 写回答

1条回答 默认 最新

  • 叫兽-郭老师 Java领域新星创作者 2022-04-11 10:36
    关注

    for 循环前需要先判断下数据是不是有
    if(sheet.LastRowNum>0){
    for (int i = 0; i <= sheet.LastRowNum; i++){
    ...
    }
    }

    if (row.GetCell(0).ToString() == "INVOICENO") 这个判断也有问题
    用equles
    if ( "INVOICENO".equles(row.GetCell(0).ToString()))

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 4月19日
  • 已采纳回答 4月11日
  • 创建了问题 4月11日

悬赏问题

  • ¥15 用verilog实现tanh函数和softplus函数
  • ¥15 Hadoop集群部署启动Hadoop时碰到问题
  • ¥15 求京东批量付款能替代天诚
  • ¥15 slaris 系统断电后,重新开机后一直自动重启
  • ¥15 QTableWidget重绘程序崩溃
  • ¥15 谁能帮我看看这拒稿理由啥意思啊阿啊
  • ¥15 关于vue2中methods使用call修改this指向的问题
  • ¥15 idea自动补全键位冲突
  • ¥15 请教一下写代码,代码好难
  • ¥15 iis10中如何阻止别人网站重定向到我的网站