.net 操作 excel
读取好像有几种方式,通过ADO.net, 通过Microsoft.Interop.Excel支持类库用调用COM读取,还有通过ZIP解压最终读取DOM(这个貌似蛮复杂)
这里我用的ADO.NET只介绍这一个。
![](/assets/blank.gif)
![](/assets/blank.gif)
public DataTable ExcelToDataTable(string strExcelPath, string strSheetName)
{
string strConn =
"Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + strExcelPath + ";" + "Extended Properties=Excel 5.0;";
string strExcel = string.Format("select * from [{0}$]", strSheetName);
DataSet ds = new DataSet();
OleDbDataAdapter adapter = new OleDbDataAdapter(strExcel, strConn);
adapter.Fill(ds, strSheetName);
conn.Close();
return ds.Tables[strSheetName];
}
参数: StrExcelPath Excel文件的路径,strSheetName 要读取表的名称
这里贴个读SheetName的代码,这个是调用Microsoft.Interop.Excel来读取
Excel.Workbook theWorkbook = ExcelObj.Workbooks.Open("Excel文件路径", 0, true, 5, "", "", true, Excel.XlPlatform.xlWindows, "\t", false, false, 0, true);
Excel.Sheets sheets = theWorkbook.Worksheets;
Excel.Worksheet worksheet = (Excel.Worksheet)sheets.get_Item(1);
ExecName = worksheet.Name;
theWorkbook.Close(null, null, null);//记得要关闭,否则程序关闭,Excel的进程还在
2.创建新的excel文件
Excel._Workbook xBk; //工作薄 相当于一个Excel文件
Excel._Worksheet xSt; //工作Sheet 一个文件里的表
xBk = myExcel.Workbooks.Add(true); //允许添加 sheet
object missing = System.Reflection.Missing.Value;//空值
myExcel.Sheets.Add(missing, missing, 1, Excel.XlSheetType.xlWorksheet);//添加sheet
xSt = (Excel._Worksheet)xBk.ActiveSheet;//得到默认sheet
xSt.Name = "新的表"; //这里设置表名
xBk.SaveAs( “保存路径” , missing, missing,
missing, missing, missing, Excel.XlSaveAsAccessMode.xlShared,
missing, missing, missing, missing); //保存文件
myExcel.Quit(); //同样要记得关闭
3.添加内容
这里只说一般数据的添加,图表的就不介绍了, 在Excel的操作里一般是以表格和范围为单位,行或列是从1开始而不是从0开始
先介绍一下格式设置,如下
如设置第一行字体为红色:((Excel.Range)xSt.Rows[1, Type.Missing]).Font.Color = 0xFF0000; //xSt 是上边代码的变量名,颜色值是用16进制RGB
设置第二列为百分数的格式 ((Excel.Range)xSt.Columns[2, Type.Missing]).NumberFormat = "0.00%";
备常用格式:文本:@ 日期:yyyy/mm/dd 数字:#,##0.00 货币:¥#,##0.00 百分比:0.00%
上边两种为行选择和列选择,如果要选择第1行第2列到第1行第5列就用get_Range();
xSt.get_Range(xSt.Cells[1,2],xSt.Cells[1,5])
如果需要其它格式,如单元格背景,边框,字体样式 ,查下文档。不过大部分从点出来的方法名就能知道了
再就是添加内容,直接写点代码参考。
//这里dt 是DataTable数据源
foreach( DataRow dr in dt.Rows )
{
int j = 1; //从第1列开始
myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString();
myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString();
myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString();
myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString();
myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString();
myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString();
//用公式的情况,显示A+B+C+D的结果
myExcel.Cells[rowIdx, j++] = string.Format("=SUM(A{0}:D{0})",rowIdx);
rowIdx++;
}
写完了save一下 xBk.Save(),还是记得要关闭。
![](/assets/blank.gif)
![](/assets/blank.gif)
首先创建 Excel 对象,使用ComObj: var ExcelApp: Variant; ExcelApp := CreateOleObject( 'Excel.Application' );
注意程序结束时释放变量 ExcelApp:=unassigned;
1 显示当前窗口: ExcelApp.Visible := True;
2 更改 Excel标题栏: ExcelApp.Caption := '应用程序调用 Microsoft Excel';
3 添加新工作簿: ExcelApp.WorkBooks.Add;
4 打开已存在的工作簿: ExcelApp.WorkBooks.Open( 'C:ExcelDemo.xls' );
5 设置第2个工作表为活动工作表: ExcelApp.WorkSheets[2].Activate; 或 ExcelApp.WorksSheets[ 'Sheet2' ].Activate;
添加工作表 ExcelApp.WorkSheets.add; 工作表重命名 ExcelApp.WorkSheets[1].Name:='工作表1';
或者ExcelApp.WorkSheets['Sheet1'].Name:='工作表1'; 工作表数目 ExcelApp.WorkSheets.Count
6 给单元格赋值: ExcelApp.Cells[1,4].Value := '第一行第四列';
7 设置指定列的宽度(单位:字符个数),以第一列为例: ExcelApp.ActiveSheet.Columns[1].ColumnsWidth := 5;
8 设置指定行的高度(单位:磅)(1磅=0.035厘米),以第二行为例: ExcelApp.ActiveSheet.Rows[2].RowHeight := 1/0.035; // 1厘米
9 在第8行之前插入分页符: ExcelApp.WorkSheets[1].Rows.PageBreak := 1;
10 在第8列之前删除分页符: ExcelApp.ActiveSheet.Columns[4].PageBreak := 0;
11 指定边框线宽度: ExcelApp.ActiveSheet.Range[ 'B3:D4' ].Borders[2].Weight := 3; 1-左 2-右 3-顶 4-底 5-斜( ) 6-斜( / )
12 清除第一行第四列单元格公式: ExcelApp.ActiveSheet.Cells[1,4].ClearContents;
13 设置第一行字体属性: ExcelApp.ActiveSheet.Rows[1].Font.Name := '隶书'; ExcelApp.ActiveSheet.Rows[1].Font.Color := clBlue; ExcelApp.ActiveSheet.Rows[1].Font.Bold := True;
ExcelApp.ActiveSheet.Rows[1].Font.UnderLine := True;
14 进行页面设置:
a.页眉: ExcelApp.ActiveSheet.PageSetup.CenterHeader := '报表演示';
b.页脚: ExcelApp.ActiveSheet.PageSetup.CenterFooter := '第&P页';
c.页眉到顶端边距2cm: ExcelApp.ActiveSheet.PageSetup.HeaderMargin := 2/0.035;
d.页脚到底端边距3cm: ExcelApp.ActiveSheet.PageSetup.HeaderMargin := 3/0.035;
e.顶边距2cm ExcelApp.ActiveSheet.PageSetup.TopMargin := 2/0.035;
f.底边距2cm ExcelApp.ActiveSheet.PageSetup.BottomMargin := 2/0.035;
g.左边距2cm: ExcelApp.ActiveSheet.PageSetup.LeftMargin := 2/0.035;
h.右边距2cm: ExcelApp.ActiveSheet.PageSetup.RightMargin := 2/0.035;
i.页面水平居中: ExcelApp.ActiveSheet.PageSetup.CenterHorizontally := 2/0.035;
j.页面垂直居中: ExcelApp.ActiveSheet.PageSetup.CenterVertically := 2/0.035;
k.打印单元格网线: ExcelApp.ActiveSheet.PageSetup.PrintGridLines := True;
15 拷贝操作:
a.拷贝整个工作表: ExcelApp.ActiveSheet.Used.Range.Copy;
b.拷贝指定区域: ExcelApp.ActiveSheet.Range[ 'A1:E2' ].Copy;
c.从A1位置开始粘贴: ExcelApp.ActiveSheet.Range.[ 'A1' ].PasteSpecial;
d.从文件尾部开始粘贴: ExcelApp.ActiveSheet.Range.PasteSpecial;
16 插入一行或一列:
a. ExcelApp.ActiveSheet.Rows[2].Insert;
b. ExcelApp.ActiveSheet.Columns[1].Insert;
17 删除一行或一列:
a. ExcelApp.ActiveSheet.Rows[2].Delete;
b. ExcelApp.ActiveSheet.Columns[1].Delete;
18 打印预览工作表: ExcelApp.ActiveSheet.PrintPreview;
19 打印输出工作表: ExcelApp.ActiveSheet.PrintOut;
20 工作表保存: if not ExcelApp.ActiveWorkBook.Saved then ExcelApp.ActiveSheet.PrintPreview;
21 工作表另存为: ExcelApp.SaveAs( 'C:ExcelDemo1.xls' );
22 放弃存盘: ExcelApp.ActiveWorkBook.Saved := True;
23 关闭工作簿: ExcelApp.WorkBooks.Close;
24 退出Excel: ExcelApp.Quit;
转载于:https://www.cnblogs.com/hanf/archive/2009/10/17/1585075.html
.net 操作 excel相关推荐
- python excel操作单元格_python 操作excel表格的方法
说明:由于公司oa暂缺,人事妹子在做考勤的时候,需要通过几个excel表格去交叉比对员工是否有旷工或迟到,工作量大而且容易出错. 这时候it屌丝的机会来啦,花了一天时间给妹子撸了一个自动化脚本. 1. ...
- C#在客户端和服务端操作Excel文件
一.在客户端把数据导入到Excel文件步骤 1.创建Excel application对象,打开或生成Excel文件 //服务端创建StringBuilder对象 System.Text.St ...
- C#如何在Form中嵌入并且操作Excel表格
网上比较多讲述如何操作excel表的文章,但都是启动excel的窗口来打开excel数据文件.有时候需要把excel表嵌入到自己程序的form中,给客户一个不用切换窗口的操作界面,似乎更好.这在vc中 ...
- c#操作Excel整理总结
大家好,这是我在工作中总结的关于C#操作Excel的帮助类,欢迎大家批评指正! using System; using System.Collections.Generic; using System ...
- C#操作excel(多种方法比较)
我们在做excel资料的时候,通常有以下方法. 一.导入导出excel常用方法: 1.用查询表的方式查询并show在数据集控件上. 代码 public static string strCon = & ...
- python连接excel存放数据_有了这篇python操作Excel学习笔记,以后储存数据 办公很轻松!...
最近在做一些数据处理和计算的工作,因为数据是以.csv格式保存的,因此刚开始直接用Excel来处理.但是做着做着发现重复的劳动其实并没有多大的意义,于是就想着写个小工具帮着处理.以前正好在一本书上看到 ...
- openpyxl 操作 Excel表的格基本用法
在本教程中,将Python3和openpyxl库一起使用来操作 Excel 表格. 本文将介绍如下操作: 如何在内存中创建工作簿 如何从工作簿中检索.创建.复制.移动和删除工作表 如何从文件创建工作簿 ...
- java操作excel常用的两种方式
转载自:https://www.cnblogs.com/wangyang108/p/6030420.html Excel是我们平时工作中比较常用的用于存储二维表数据的,JAVA也可以直接对Excel进 ...
- 使用VC来操作Excel表格的源码
下面的代码段是关于使用VC来操作Excel表格的的代码,应该对小伙伴们也有用. if (CoInitialize(NULL) != 0) { AfxMessageBox("初始化COM支持库 ...
- C# 操作Excel之旁门左道 [ C# | Excel ]
一.目的 从数据库导出数据到Excel中并锁定部分数据不让修改.这里以学生成绩表为例, 学生编号.学生姓名.学生成绩 三个字段从数据库提取,并锁定,老师评价栏在导出后可输入. 二.实现 1. 制作Ex ...
最新文章
- 【Python】实现将testlink上的用例指定格式保存至Excel,用于修改上传
- java 耗时_Java使用简单的方法计算代码耗时
- 18 | 为什么这些SQL语句逻辑相同,性能却差异巨大?
- sql-server基础三(select 、update、insert,delete)
- CPU虚拟化系列文章之虚拟机切入和退出
- html css表格样式模板_HTML amp; CSS 基础入门【4】列表及其样式
- 明显调用的表达式前的括号必须具有(指针)函数类型
- 现代信号处理——自适应滤波器(RLS自适应滤波器)
- SQL语句实现模糊查询
- 关于微信服务号使用百度地图获取定位不准问题
- Android11不如,1200万像素的iPhone11真的不如4800万像素的安卓?
- getopt Python
- 微信小程序添加开发者、赋予权限、添加体验者
- Office LTSC 2021离线安装ISO镜像
- 简单的位图转换矢量图方法
- 关于Berkeley DB打开创建数据库文件
- 连接打印服务器显示无合适驱动,Silex DS-510打印服务器驱动(解决DS-510打印机连接问题)V7.2.1 最新版...
- 2019年程序员岗位招聘信息分析
- JVM读书笔记-1.来福与旺财的养牛场
- 线性代数与数据学习:MIT教授Gilbert Strang帮你打下坚实的数学基础