日期:2014-05-18  浏览次数:20987 次

求助:不包含“aTableAdapter”的定义
“newform.WenBen”不包含“aTableAdapter”的定义,并且找不到可接受类型为“newform.WenBen”的第一个参数的扩展方法“aTableAdapter”(是否缺少 using 指令或程序集引用?)
 private void button1_Click(object sender, EventArgs e)
  {
   
  //打开一个文件选择框
  OpenFileDialog ofd = new OpenFileDialog();
  ofd.Title = "Excel文件";
  ofd.FileName = "";
  ofd.InitialDirectory =
  Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments);//为了获取特定的系统文件夹,可以使用System.Environment类的静态方法GetFolderPath()。该方法接受一个Environment.SpecialFolder枚举,其中可以定义要返回路径的哪个系统目录
  ofd.Filter = "Excel文件(*.xls)|*.xls";
  ofd.ValidateNames = true; //文件有效性验证ValidateNames,验证用户输入是否是一个有效的Windows文件名
  ofd.CheckFileExists = true; //验证路径有效性
  ofd.CheckPathExists = true; //验证文件有效性


  string strName = string.Empty;
  if (ofd.ShowDialog() == DialogResult.OK)
  {
  strName = ofd.FileName;
  }

  if (strName == "")
  {
  MessageBox.Show("没有选择Excel文件!无法进行数据导入");
  return;
  }
  //调用导入数据方法
  EcxelToDataGridView(strName, this.dataGridView1);
  }

  public void EcxelToDataGridView(string filePath,DataGridView dgv)
  {
  //根据路径打开一个Excel文件并将数据填充到DataSet中
  string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source = " + filePath + 
  ";Extended Properties ='Excel 8.0;HDR=NO;IMEX=1'";//导入时包含Excel中的第一行数据,并且将数字和字符混合的单元格视为文本进行导入
  OleDbConnection conn = new OleDbConnection(strConn);
  conn.Open();
  string strExcel = "";
  OleDbDataAdapter myCommand = null;
  DataSet ds = null;
  strExcel = "select * from [sheet1$]";
  myCommand = new OleDbDataAdapter(strExcel, strConn);
  ds = new DataSet();
  myCommand.Fill(ds, "table1");

  //根据DataGridView的列构造一个新的DataTable
  DataTable tb = new DataTable();
  foreach (DataGridViewColumn dgvc in dgv.Columns)
  {
  if (dgvc.Visible && dgvc.CellType != typeof(DataGridViewCheckBoxCell))
  {
  DataColumn dc = new DataColumn();
  dc.ColumnName = dgvc.DataPropertyName;
  //dc.DataType = dgvc.ValueType;//若需要限制导入时的数据类型则取消注释,前提是DataGridView必须先绑定一个数据源那怕是空的DataTable
  tb.Columns.Add(dc);
  }
  }

  //根据Excel的行逐一对上面构造的DataTable的列进行赋值
  foreach (DataRow excelRow in ds.Tables[0].Rows)
  {
  int i = 0;
  DataRow dr = tb.NewRow();
  foreach (DataColumn dc in tb.Columns)
  {
  dr[dc] = excelRow[i];
  i++;
  }
  tb.Rows.Add(dr);
  }
  //在DataGridView中显示导入的数据
  dgv.DataSource = tb;
  }

  private void WenBen_Load(object sender, EventArgs e)
  {