添加命名空间usingSystem.Data.OleDb;//Excel表数据操作
//选择文件
private void simpleButton1_Click(object sender, EventArgs e)
{
textEdit1.Text = SelectPath();
}
private string SelectPath()
{
string path = string.Empty;
var openFileDialog = new Microsoft.Win32.OpenFileDialog()
{
Filter = "Files (*.xls)|*.xls|(*.xlsx)|*.xlsx"//如果需要筛选txt文件("Files (*.txt)|*.txt")
//Filter = "Files (全部文件)|*.*"
};
var result = openFileDialog.ShowDialog();
if (result == true)
{
path = openFileDialog.FileName;
}
return path;
}
//读取Excel文件
public static DataTable ReadExcel(string filePath)
{
try
{
//创建连接,引用协议
string strConn;
//strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filePath + ";Extended Properties='Excel8.0;HDR=False;IMEX=1'";
strConn = "Provider=Microsoft.ACE.OLEDB.12.0;Data source=" + filePath + ";Extended Properties='Excel 12.0; HDR=NO;IMEX=1'";//此连接可以操作.xls与.xlsx文件
OleDbConnection OleConn=new OleDbConnection(strConn);
OleConn.Open();
String sql = "SELECT* FROM[Sheet1$]";//可是更改Sheet名称,比如sheet2,等等
OleDbDataAdapter OleDaExcel=new OleDbDataAdapter(sql,OleConn);
DataSet OleDsExcle=new DataSet();
OleDaExcel.Fill(OleDsExcle,"Sheet1");
OleConn.Close();
return OleDsExcle.Tables["Sheet1"];
}
catch(Exception err)
{
MessageBox.Show("数据绑定Excel失败!失败原因:"+err.Message,"提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information);
return null;
}
}
DataTable dt = ReadExcel(textEdit1.Text); ;//存放Excel表的内容到DataTable中
以上代码实现了Excel的读取,并把内容存放在dataset中.接着,讲解下如何应用该datatable。
方式一:把datatable内容读取到DataGridView中,显示所有Excel内容。1.先添加DataGridView控件,并命名为dataGridView12.添加DataGridView数据绑定语句如下:DataTabledt;//存放Excel表的内容dt=ReadExcel(“E://1.xls”);//这里的路径,指的是你Excel表格存放的路径dataGridView1.DataSource=dt;
方式二:1.添加一个label标签,命名为label12.添加语句; label1.Text=dt.Rows[x][y].ToString(); //这里的参数x,y,对应的是你Excel表格的单元格内容。注意下,x,y是从0开始取值。 最后还有一点要说明,就是读取的内容是从Excel表格的第二行开始。第一行,类似于数据库中的字段名,是不读取的