C#读取execl到datatable,设置execl单元格颜色
2013-09-24 16:06
549 查看
public class OperateExecl
{
//读取execl到datatable
public static DataTable ReadFile(string path)
{ string strConn="";
if (Path.GetExtension(path).ToLower().Equals(".xlsx")) //Excel2007
{
strConn = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + path + ";Extended Properties='Excel 12.0;HDR=YES';";
}
else //excel2003
{
strConn = "Provider = Microsoft.Jet.OLEDB.4.0;Data Source=" + path + ";Extended Properties=Excel 8.0;";
}
OleDbConnection conn = new OleDbConnection(strConn);
conn.Open();
string strExcel = "";
OleDbDataAdapter myCommand = null;
DataSet ds = null;
DataTable schemaTable = conn.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null);
string tableName = schemaTable.Rows[0][2].ToString().Trim();
strExcel = "select * from [" + tableName + "]";
myCommand = new OleDbDataAdapter(strExcel, strConn);
ds = new DataSet();
myCommand.Fill(ds, "table1");
return ds.Tables[0];
}
//设置单元格颜色
public static void SetColor()
{
Microsoft.Office.Interop.Excel.ApplicationClass execlapp = new Microsoft.Office.Interop.Excel.ApplicationClass(); Microsoft.Office.Interop.Excel.Workbook wb = execlapp.Workbooks.Open(@"C:\Users\zhangshixiao\Desktop\数据导入模板(1).xlsx"); Microsoft.Office.Interop.Excel.Worksheet ws = (Microsoft.Office.Interop.Excel.Worksheet)wb.Sheets.get_Item(1); Microsoft.Office.Interop.Excel.Range range = (Microsoft.Office.Interop.Excel.Range)ws.Cells[1, 1];
range.Interior.Color = Color.FromArgb(255, 0, 0);
wb.Save();
wb.Close();
}
}
{
//读取execl到datatable
public static DataTable ReadFile(string path)
{ string strConn="";
if (Path.GetExtension(path).ToLower().Equals(".xlsx")) //Excel2007
{
strConn = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + path + ";Extended Properties='Excel 12.0;HDR=YES';";
}
else //excel2003
{
strConn = "Provider = Microsoft.Jet.OLEDB.4.0;Data Source=" + path + ";Extended Properties=Excel 8.0;";
}
OleDbConnection conn = new OleDbConnection(strConn);
conn.Open();
string strExcel = "";
OleDbDataAdapter myCommand = null;
DataSet ds = null;
DataTable schemaTable = conn.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null);
string tableName = schemaTable.Rows[0][2].ToString().Trim();
strExcel = "select * from [" + tableName + "]";
myCommand = new OleDbDataAdapter(strExcel, strConn);
ds = new DataSet();
myCommand.Fill(ds, "table1");
return ds.Tables[0];
}
//设置单元格颜色
public static void SetColor()
{
Microsoft.Office.Interop.Excel.ApplicationClass execlapp = new Microsoft.Office.Interop.Excel.ApplicationClass(); Microsoft.Office.Interop.Excel.Workbook wb = execlapp.Workbooks.Open(@"C:\Users\zhangshixiao\Desktop\数据导入模板(1).xlsx"); Microsoft.Office.Interop.Excel.Worksheet ws = (Microsoft.Office.Interop.Excel.Worksheet)wb.Sheets.get_Item(1); Microsoft.Office.Interop.Excel.Range range = (Microsoft.Office.Interop.Excel.Range)ws.Cells[1, 1];
range.Interior.Color = Color.FromArgb(255, 0, 0);
wb.Save();
wb.Close();
}
}
相关文章推荐
- c#的DateTime.Now函数详解
- C#的switch与二维数组.....
- c# in deep 之委托
- C#中使用全局Hotkey
- C#正则表达式查找匹配循环替换内容
- c#调用dll详解
- C#注释标签
- C#中HashTable的用法
- 利用dynamic类型对C#泛型参数运算
- C# winfrom利用多线程实现滚动条效果
- CLR via C#(第3版).pdf 清晰版.带自己整的 目录
- C#字符串操作 取文本左边 取文本右边 取文本中间 取文本中间到List集合 指定文本倒序
- c#一个FTP操作封装类FTPHelper
- C# 鼠標離開后觸發動作(去DB中查詢判斷是否已存在此資料)
- 图片压缩,修改图片dpi值,更改图片大小
- C# 命名规则
- C#中抽象类和接口的区别
- C#求圆的面积
- [转]C# 获取指定目录下所有文件信息、移动目录、拷贝目录
- C#读取EXECL关键代码