.NET操作Excel实例分享

  次阅读 作者:智能小宝 来源:互联网 2016-01-26 10:53 我要评论(0)

这篇文章主要介绍了.NET操作Excel实例,有需要的朋友可以参考一下

1. 读取

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

这里我用的ADO.NET只介绍这一个。

代码如下:

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])

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...