时间:2021-05-02
把整个Excel当做数据库读入的方式
string ExcelConnection = "Provider=Microsoft.Jet.Oledb.4.0;Data Source={0};Extended Properties=Excel 8.0";
string ExcelFileConnection = string.Format(ExcelConnection,FileName);
string queryString = string.Format("select * from [{0}$]", sheetName);
OleDbConnection oledbConn = new OleDbConnection(connString);
OleDbDataAdapter oledbAdap = new OleDbDataAdapter(queryString, oledbConn);
DataSet dsResult = new DataSet();
oledbAdap.Fill(dsResult, fileName);
把整个Excel当做Com对象读入的方式
打开Excel
Microsoft.Office.Interop.Excel.ApplicationappExcel = new Microsoft.Office.Interop.Excel.Application();
Workbook wbkExcel = appExcel.Workbooks.Open(fileName , Missing.Value , Missing.Value , Missing.Value , Missing.Value , Missing.Value , Missing.Value , Missing.Value , Missing.Value , Missing.Value , Missing.Value , Missing.Value , Missing.Value , Missing.Value , Missing.Value);
关闭Excel
wbkExcel .Close(false, fileName, false);
另存为Excel
wbkExcel .SaveCopyAs(savePath.FileName);
取得sheet对象
Worksheet wstExcel = wbkExcel .Sheets[sheetName];
取得一个Cell
public static Range GetOneCell(Worksheet wst,int ColumnIndex, int RowIndex){ Range cell = (Range)wst.Cells[RowIndex, ColumnIndex]; return cell;}
取得一行
public static Range GetOneRowCells(Worksheet wst, int RowIndex){ Range row = wst.get_Range(wst.Cells[RowIndex, 1], wst.Cells[RowIndex, wst.Columns.Count]); return row;}
取得一列
public static Range GetOneColumnCells(Worksheet wst, int ColumnIndex){ Range column = wst.get_Range(wst.Cells[1, ColumnIndex], wst.Cells[wst.Rows.Count, ColumnIndex]); return column;}
同一本workbook的不同sheet的copy
//模板文件
Workbook wbkTemplate = T_EXECLE.GetWorkBook(this.TemplateFullName);
//被copy的sheet拷贝到自己的后面
wsData.Copy(wsData, Missing.Value);
//取得copy后的sheetWorksheet newSheet = (Worksheet)wbkTemplate.ActiveSheet;
//重命sheet名newSheet.Name = InstanceSheetNames[index];
行的copy(带格式)
//模板行的取得
Range TemplateRow = T_EXECLE.GetOneRowCells(classSheet, StartIndex + 1);
//插入一个copy行
//1 Select Template RowTemplateRow.Select();//2 Insert Blank RowTemplateRow.EntireRow.Insert(XlInsertShiftDirection.xlShiftDown, Missing.Value);//3 Select NewRowRange newRange = TemplateRow.Application.ActiveCell;//4 Paste Data
TemplateRow.Copy(newRange);
Range的copy(带格式)
//要copy的数据
Range dataRange = dataSheet.get_Range(dataSheet.Cells[StartIndex, "B"], InstanceSheet.Cells[EndIndex, "K"]);
//copy到那个sheet的Range内Range copyWhere = TemplateSheet.get_Range(TemplateSheet.Cells[T_StartIndex, "B"], TemplateSheet.Cells[T_StartIndex + I_Count, "R"]);
//copy执行dataRange.Copy(copyWhere);
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了C#使用oledb操作excel文件的方法。分享给大家供大家参考。具体分析如下:不管什么编程语言都会提供操作Excel文件的方式,C#操作Exce
本文实例讲述了C#自定义导出数据到Excel的类。分享给大家供大家参考。具体如下:C#自定义Excel操作类,可以用于将DataTable导出到Excel文件,
C#操作Excel的方法有很多种,常见的有微软官方的OLEAutomation,Apache的POI等。这里介绍的是POI翻译成C#的NPOI。POI是Apac
本文具体给出了C#常用的文件操作方法,包括C#追加文件,C#拷贝文件,C#删除文件,C#移动文件,C#创建目录。(1)C#追加文件StreamWritersw=
本文分享了c#操作Excel的相关代码,还是比较全面的,其实无外乎存取,增删改查等操作,参考下。具体代码://引用Microsoft.Office.Intero