Winform–C#读取Excel到DataGridView(两种方式)
一、 通过Microsoft.Office.Interop.Excel
页面模板如下:
源代码:
using System;
using Excel = Microsoft.Office.Interop.Excel;
using System.Windows.Forms;
namespace ReadExcel
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
this.excel1 = new Excel.Application();
if (excel1 == null)
{
MessageBox.Show("error");
System.Windows.Forms.Application.Exit();
}
excel1.Visible = false;
}
private ExcelOperate eo;
private string excelpath;
private Excel.Application excel1;
private Excel.Workbooks wbs = null;
private Excel.Workbook wb = null;
private Excel.Sheets wss;
private Excel.Worksheet ws = null;
private Excel.Range range1 = null;
private void 打开_Click(object sender, EventArgs e)
{
OpenFileDialog openFileDialog1 = new OpenFileDialog();
openFileDialog1.Title = "打开excel文件";
openFileDialog1.Filter = "Excel文件(*.xls)|*.xls|Excel文件(*.xlsx)|*.xlsx";
openFileDialog1.InitialDirectory = @"C:\Users\Administrator\Desktop";
openFileDialog1.RestoreDirectory = true;
if (openFileDialog1.ShowDialog() == DialogResult.OK)
{
excelpath = openFileDialog1.FileName;
eo = new ExcelOperate();
readExcel(excelpath);
}
}
void readExcel(string path)
{
object miss = System.Reflection.Missing.Value;
excel1.UserControl = true;
excel1.DisplayAlerts = false;
excel1.Application.Workbooks.Open(excelpath, miss, miss, miss, miss,
miss, miss, miss, miss,
miss, miss, miss, miss,
miss, miss);
wbs = excel1.Workbooks;
wss = wbs[1].Worksheets;
ws = (Excel.Worksheet)wss.get_Item(1);
int rowNum = ws.UsedRange.Cells.Rows.Count;
int colNum = ws.UsedRange.Cells.Columns.Count;
string cellStr = null;
char ch = 'A';
for (int i = 0; i < colNum; i++)
{
dataGridView1.Columns.Add(i.ToString(), ch.ToString());
dataGridView1.Rows.Add(rowNum);
for (int j = 0; j < rowNum; j++)
{
cellStr = ch.ToString() + (j + 1).ToString();
dataGridView1[i, j].Value = ws.UsedRange.Cells.get_Range(cellStr, miss).Text.ToString();
}
ch++;
}
}
}
}
ExcelOperate .cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Web;
public class ExcelOperate
{
private object mValue = System.Reflection.Missing.Value;
public ExcelOperate()
{
}