.net 操作 excel

摘要:
然而,大多数方法都可以从您单击的方法的名称中得知,然后您可以添加内容并直接编写代码引用。introwIdx=2;//从第二行开始//这里dt是每个{intj=1;//的DataTable数据源。从第一列开始,myExcel.Cells[rowIdx,j++]=dr[“dt列名”].ToString();myExcel.Ccells[rowIdx,j++]=dr[“dt列名称”].ToString();myExcel.Cells[rowIdx,j++]=dr[“dt-column name”]。ToString()[rowIdx,j++]=dr[“dt列名”]。ToString();myExcel。单元格[rowIdx,j++]=dr[“dt列名”]。ToString();myExcel。单元格[rowIdx,j++]=dr[“dt列名”]。ToString();//如果使用公式,则为a+B+C+DmyExcel的结果。单元格[rowIdx,j++]=字符串。显示格式;rowIdx++;}保存完成后,请记住关闭xBk。保存()。
1. 读取
      读取好像有几种方式,通过ADO.net, 通过Microsoft.Interop.Excel支持类库用调用COM读取,还有通过ZIP解压最终读取DOM(这个貌似蛮复杂)
这里我用的ADO.NET只介绍这一个。
.net 操作 excel第1张.net 操作 excel第2张读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(),还是记得要关闭。

.net 操作 excel第3张.net 操作 excel第4张贴点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 := 31-左 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; 

免责声明:文章转载自《.net 操作 excel》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇python 堆排序强大的strace命令用法详解下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

C# 操作Excel大全

//引用Microsoft.Office.Interop.Excel.dll文件 //添加using usingMicrosoft.Office.Interop.Excel; usingExcel=Microsoft.Office.Interop.Excel; //设置程序运行语言 System.Globalization.CultureInf...

APP 安全测试点概述

一、安装包测试 1.1 关于反编译   目的是为了保护公司的知识产权和安全方面的考虑等,一些程序开发人员会在源码中硬编码一些敏感信息,如密码。而且若程序内部一些设计欠佳的逻辑,也可能隐含漏洞,一旦源码泄漏,安全隐患巨大。   为了避免这些问题,除了代码审核外,通常开发的做法是对代码进行混淆,混淆后源代码通过反软件生成的源代码是很难读懂的,测试中,我们可以...

Linux 的软件管理及配置

1. 对比:Windows 和 Linux 上软件的安装与卸载 大部分 Linux 使用者都是从 Windows 转过来的,先对这俩做个对比,有助理解。 就像在 Windows 下,很多软件也有安装版与免安装版一样,在 Linux 下也有这样的差别。 1.1. Linux 的包管理工具(rpm/yum、dpkg/apt) Windows 下的安装版软件在安...

关于使用BetterIntelliJ激活IntelliJ IDEA

第一步: 下载解压文件,把文件放到一个位置(尽量不要有中文路径),激活后,不要删除。 (具体如何下载BetterIntelliJ文件,百度查一下) 第二步: 安装软件后,打开软件,提示需要注册,勾选试用(Evaluate for free)选项,点击Evaluate进入IDE。 说明:如果不能出现这个界面,请打开reset_eval文件夹执行相应的重置脚...

微信开放平台开发——网页微信扫码登录(OAuth2.0)

1、OAuth2.0 OAuth(开放授权)是一个开放标准,允许用户让第三方应用访问该用户在某一网站上存储的私密的资源(如照片,视频,联系人列表),而无需将用户名和密码提供给第三方应用。 允许用户提供一个令牌,而不是用户名和密码来访问他们存放在特定服务提供者的数据。每一个令牌授权一个特定的网站(例如,视频编辑网站)在特定的时段(例如,接下来的2小时内)内...

数字签名(代码签名)流程

数字签名(代码签名)流程 Authenticode : 这里翻译为数字认证代码。 code sign : 字面的翻译为代码签名,但是通常的我们称为数字签名,以下的文中均称为数字签名。一 数字认证码如果你是软件开发人员,你可能已经知道windows系统和一些浏览器(例如IE,Firefox)使用一种称为数字认证代码的技术来标识软件的发行商,来检查软件没有被...