尝试加载excel时,C#datatable为空
我正在使用ExcelDataReader扩展将excel文件导入C#datagridview。我可以打开文件并获取它的工作表,但每当我尝试单击工作表时,我的程序就会中断,并说它的datatable为空。请帮帮我 我不确定是var导致了问题,还是我没有将excel数据更新到datatable中尝试加载excel时,C#datatable为空,c#,C#,我正在使用ExcelDataReader扩展将excel文件导入C#datagridview。我可以打开文件并获取它的工作表,但每当我尝试单击工作表时,我的程序就会中断,并说它的datatable为空。请帮帮我 我不确定是var导致了问题,还是我没有将excel数据更新到datatable中 namespace Dashboard { public partial class Import_Excel : Form { public Import_Excel() {
namespace Dashboard {
public partial class Import_Excel : Form {
public Import_Excel() {
InitializeComponent();
}
DataSet result;
private void btnLoad_Click(object sender, EventArgs e) {
using (OpenFileDialog ofd = new OpenFileDialog()) {
if (ofd.ShowDialog() == DialogResult.OK) {
using (var stream = File.Open(ofd.FileName, FileMode.Open, FileAccess.Read)) {
using (var reader = ExcelReaderFactory.CreateReader(stream)) {
var result = reader.AsDataSet(new ExcelDataSetConfiguration() {
UseColumnDataType = true,
ConfigureDataTable = (data) => new ExcelDataTableConfiguration() {
UseHeaderRow = true
}
});
cboSheet.Items.Clear();
DataTableCollection table = result.Tables;
foreach (DataTable dt in result.Tables) {
cboSheet.Items.Add(dt.TableName);
}
reader.Close();
}
}
}
}
}
private void cboSheet_SelectedIndexChanged(object sender, EventArgs e) {
dataGridView1.DataSource = result.Tables[cboSheet.SelectedIndex];
}
private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e) {
}
}
}
如果方法
cboSheet\u SelectedIndexChanged
发生在btnLoad\u Click()
之前,则结果将为空,因此结果。表
抛出NullReferenceException
private void cboSheet_SelectedIndexChanged(object sender, EventArgs e)
{
if(result != null) {
dataGridView1.DataSource = result.Tables[cboSheet.SelectedIndex];
}
}
或者只使用:dataGridView1.DataSource=result?.Tables[cboSheet.SelectedIndex]代码>(将其设置为空)