1. 读取
      读取好像有几种方式,通过ADO.net, 通过Microsoft.Interop.Excel支持类库用调用COM读取,还有通过ZIP解压最终读取DOM(这个貌似蛮复杂)
这里我用的ADO.NET只介绍这一个。

读Excel到Table
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.ApplicationClass myExcel = new Excel.ApplicationClass();      //实例一个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])
如果需要其它格式,如单元格背景,边框,字体样式 ,查下文档。不过大部分从点出来的方法名就能知道了
再就是添加内容,直接写点代码参考。

int rowIdx = 2; //从第2行列始
//这里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(),还是记得要关闭。

贴点Delphi的代码参考
首先创建 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相关推荐

  1. python excel操作单元格_python 操作excel表格的方法

    说明:由于公司oa暂缺,人事妹子在做考勤的时候,需要通过几个excel表格去交叉比对员工是否有旷工或迟到,工作量大而且容易出错. 这时候it屌丝的机会来啦,花了一天时间给妹子撸了一个自动化脚本. 1. ...

  2. C#在客户端和服务端操作Excel文件

    一.在客户端把数据导入到Excel文件步骤 1.创建Excel application对象,打开或生成Excel文件 //服务端创建StringBuilder对象     System.Text.St ...

  3. C#如何在Form中嵌入并且操作Excel表格

    网上比较多讲述如何操作excel表的文章,但都是启动excel的窗口来打开excel数据文件.有时候需要把excel表嵌入到自己程序的form中,给客户一个不用切换窗口的操作界面,似乎更好.这在vc中 ...

  4. c#操作Excel整理总结

    大家好,这是我在工作中总结的关于C#操作Excel的帮助类,欢迎大家批评指正! using System; using System.Collections.Generic; using System ...

  5. C#操作excel(多种方法比较)

    我们在做excel资料的时候,通常有以下方法. 一.导入导出excel常用方法: 1.用查询表的方式查询并show在数据集控件上. 代码 public static string strCon = & ...

  6. python连接excel存放数据_有了这篇python操作Excel学习笔记,以后储存数据 办公很轻松!...

    最近在做一些数据处理和计算的工作,因为数据是以.csv格式保存的,因此刚开始直接用Excel来处理.但是做着做着发现重复的劳动其实并没有多大的意义,于是就想着写个小工具帮着处理.以前正好在一本书上看到 ...

  7. openpyxl 操作 Excel表的格基本用法

    在本教程中,将Python3和openpyxl库一起使用来操作 Excel 表格. 本文将介绍如下操作: 如何在内存中创建工作簿 如何从工作簿中检索.创建.复制.移动和删除工作表 如何从文件创建工作簿 ...

  8. java操作excel常用的两种方式

    转载自:https://www.cnblogs.com/wangyang108/p/6030420.html Excel是我们平时工作中比较常用的用于存储二维表数据的,JAVA也可以直接对Excel进 ...

  9. 使用VC来操作Excel表格的源码

    下面的代码段是关于使用VC来操作Excel表格的的代码,应该对小伙伴们也有用. if (CoInitialize(NULL) != 0) { AfxMessageBox("初始化COM支持库 ...

  10. C# 操作Excel之旁门左道 [ C# | Excel ]

    一.目的 从数据库导出数据到Excel中并锁定部分数据不让修改.这里以学生成绩表为例, 学生编号.学生姓名.学生成绩 三个字段从数据库提取,并锁定,老师评价栏在导出后可输入. 二.实现 1. 制作Ex ...

最新文章

  1. 【Python】实现将testlink上的用例指定格式保存至Excel,用于修改上传
  2. java 耗时_Java使用简单的方法计算代码耗时
  3. 18 | 为什么这些SQL语句逻辑相同,性能却差异巨大?
  4. sql-server基础三(select 、update、insert,delete)
  5. CPU虚拟化系列文章之虚拟机切入和退出
  6. html css表格样式模板_HTML amp; CSS 基础入门【4】列表及其样式
  7. 明显调用的表达式前的括号必须具有(指针)函数类型
  8. 现代信号处理——自适应滤波器(RLS自适应滤波器)
  9. SQL语句实现模糊查询
  10. 关于微信服务号使用百度地图获取定位不准问题
  11. Android11不如,1200万像素的iPhone11真的不如4800万像素的安卓?
  12. getopt Python
  13. 微信小程序添加开发者、赋予权限、添加体验者
  14. Office LTSC 2021离线安装ISO镜像
  15. 简单的位图转换矢量图方法
  16. 关于Berkeley DB打开创建数据库文件
  17. 连接打印服务器显示无合适驱动,Silex DS-510打印服务器驱动(解决DS-510打印机连接问题)V7.2.1 最新版...
  18. 2019年程序员岗位招聘信息分析
  19. JVM读书笔记-1.来福与旺财的养牛场
  20. 线性代数与数据学习:MIT教授Gilbert Strang帮你打下坚实的数学基础

热门文章

  1. 【Excel】UNICHAR函数展示万国码(unicode)
  2. 小米盒子显示服务器断开,小米盒子故障原因排查及检修方法
  3. 三妹,我拆了你的本-- Day One(大图赏)
  4. 小程序下拉刷新 以及loading颜色
  5. Oracle数据库第四课——PL/SQL中的条件控制
  6. cmd常用命令大全 cmd运行命令
  7. ICLR-17最佳论文作者Nicolas Papernot现场演讲:如何用PATE框架有效保护隐私训练数据?
  8. python 怎么运行的
  9. Java定义一个数组,输出数组中的最大值和最小值
  10. 配置apache的php环境,apache配置php环境的方法