3

我有一个从excel读取值并插入到表中的代码。我选择第一行作为表的列名。这里我想检查excel表第一行中的名称是否与表列名相同?这是我阅读excel的代码。

FileStream stream = 
    File.Open(Server.MapPath("~/App_Data/YoutubeVideo/" + fileName), 
    FileMode.Open, FileAccess.Read);

IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream);
excelReader.IsFirstRowAsColumnNames = true;
DataSet result = excelReader.AsDataSet();
excelReader.Close();

dt = result.Tables[0];
dt = dt.Rows.Cast<DataRow>()
            .Where(row => !row.ItemArray.All(field => field is System.DBNull))
            .CopyToDataTable();

提前感谢您的帮助....

4

1 回答 1

3

要在将数据复制到数据集之前进行检查,请使用excelReader.GetName(0)获取第一列的名称。

编辑:

看来您正在使用Excel 数据阅读器,它显然没有实现 IDataReader 的所有方法。

由于这不是一个完全实现的数据提供程序,因此您必须在加载到 DataTable 后检查名称。

在这种情况下,您可以使用if (dt.Columns[0].ColumnName == "Name").

于 2013-10-10T11:26:56.590 回答