C#读写EXCEL的简单封装

用法简单,类似于ado.net

ExcelTools.Open()

//读写

ExcelTools.SaveAndClose()

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.Office.Interop.Excel;
using System.IO;
using System.Windows.Forms;
using System.Reflection;

namespace AutoReportDeal
{
    class ExcelTools
    {
        public static Microsoft.Office.Interop.Excel.Application xlsApp = null;
        public static Microsoft.Office.Interop.Excel.Workbook workbook = null;
        public static Microsoft.Office.Interop.Excel.Worksheet worksheet = null;

        public static string str_this_path = null;

        #region 打开某EXCEL文件的某个页
        /// <param name="str_path">EXCEL文件路径</param>
        /// <param name="str_sheet">要操作的页</param>
        public static void Open(string str_path, string str_sheet)
        {
            str_this_path = str_path;
            //Excel Application
            xlsApp = new Microsoft.Office.Interop.Excel.Application();

            //Excel Workbook
            workbook = xlsApp.Workbooks.Open(str_path, 0, true, 5,
                                             System.Reflection.Missing.Value,
                                             System.Reflection.Missing.Value,
                                             false, System.Reflection.Missing.Value,
                                             System.Reflection.Missing.Value, true,
                                             false, System.Reflection.Missing.Value,
                                             false, false, false);

            //Excel Worksheet
            worksheet = (Worksheet)workbook.Worksheets[str_sheet];
        }
        #endregion

        #region 筛选日期列获得在EXCEL中的行号
        /// <param name="col_name">要进行筛选的列明</param>
        /// <param name="str_date_value">要筛选的值</param>
        /// <param name="isHasTitle">是否存在表头</param>
        /// <returns>成功返回行号,出错返回-1</returns>
        public static int GetExcelRowsIndexByDate(string col_name, string str_date_value, bool isHasTitle)
        {
            if (str_date_value == null)
                return -1;

            int row = 2;
            if (isHasTitle == false)
                row = 1;

            DateTime cTime = Convert.ToDateTime(str_date_value);
            for (; row <= worksheet.UsedRange.Rows.Count; ++row)
            {
                Microsoft.Office.Interop.Excel.Range rng = worksheet.get_Range(col_name + row.ToString(), Missing.Value);
                DateTime dTime = Convert.ToDateTime(rng.Text.ToString().Trim());
                if (cTime.Year == dTime.Year && cTime.Month == dTime.Month && cTime.Day == dTime.Day)
                    return row;
            }

            return -1;
        }
        #endregion

        #region 将值写入到当前打开的EXCEL文件中某页的某行某列单元格中
        /// <param name="row">写入当前打开的某行</param>
        /// <param name="col">写入某列</param>
        /// <param name="str_value">要写入的值</param>
        /// <returns>成功返回0,出错返回-1</returns>
        public static int WriteToExcel(int row, int col, string str_value)
        {
            if (row < 0 || col < 0 || str_value == null || xlsApp == null)
                return -1;

            worksheet.Cells[row, col] = str_value;
            return 0;
        }
        #endregion

        #region 获取当前可用页中的已用的最大行号
        /// <returns>成功返回0,出错返回-1</returns>
        public static int GetCurSheetUsedRangeRowsCount()
        {
            if (xlsApp == null)
                return -1;

            int used_rng_rows = worksheet.UsedRange.Rows.Count;

            return used_rng_rows;
        }
        #endregion

        #region 保存并关闭
        public static void CloseAndSave()
        {
            xlsApp.DisplayAlerts = false;
            xlsApp.AlertBeforeOverwriting = false;
            if (File.Exists(str_this_path))
            {
                File.Delete(str_this_path);
            }
            xlsApp.ActiveWorkbook.SaveCopyAs(str_this_path);
            xlsApp.Quit();
            xlsApp = null;
            workbook = null;
            worksheet = null;
            str_this_path = null;
        }
        #endregion
    }
}
时间: 2024-08-14 04:01:27

C#读写EXCEL的简单封装的相关文章

C# 读写Excel文件

公司遇到一些tasks,需要将分析完毕的数据结果保存在Excel文件中.陆陆续续参与了这么多tasks后,现简单总结下: 操纵Excel 文件有多种方法,每种方法都有特色,适用于不同场景. 方法1:调用Office com组件: 也就是调用Interop类.此方法适用于desktop已经安装有Windows Office的情况.功能及其强大,windows Office拥有的功能,几乎通过此都能调用.劣势是读写速度最慢. 方法2:使用ODBC技术读写Excel文件 该方法读写速度似乎最快(没有准

C++使用OLE高速读写EXCEL的源码

<C++读写EXCEL文件方式比较>. 我的代码参考的地方是这儿,再次感谢原作者 http://blog.csdn.net/gyssoft/archive/2007/04/29/1592104.aspx 我根据自己的需要做了整理,干净了一点,而后根据发现的速度问题做了一些优化. 预加载的思路来自这个帖子 http://topic.csdn.net/t/20030626/21/1962211.html 其实思路很简单,不再一个CELL一个CELL的伛数据,而是一次把表格里面所有的数据读取出来处理

MFC vs2012 Office2013 读写excel文件

近期在忙一个小项目(和同学一起搞的),在这里客户要求不但读写txt,而且可以读写excel文件,这里本以为很简单,结果...废话少说,过程如下: 笔者环境:win7 64+VS2012+Office2013+MFC. 说明:读写excel文件,通常包括1.ODBC数据库实现;2.通过解析Excel表格文件;3.通过OLE/COM的几种实现方法.本文主要研究通过OLE/COM实现对Excel表格的操作. 步骤: 1.新建MFC对话框.注意勾选自动化,否则后面加入不了需要的库,导致启动服务失败等错误

使用phpexcel类读写excel文件

使用原生php读写excel文件的博文地址: 基于使用原生php读写excel文件的不靠谱,本文将简单介绍如何使用第三方类库phpexcel来读写excel文件. 首先,需要到githut下载phpexcel类库.下载地址:https://github.com/PHPOffice/PHPExcel.

【原创】.NET读写Excel工具Spire.Xls使用(4)对数据操作与控制

              本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/4288836.html .NET读写Excel工具Spire.Xls使用文章目录:http://www.cnblogs.com/asxinyu/p/4374032.html Spire.Office for .NET是E-iceblue开发的一种企业级.NET Office编辑的软件集合,包括Spire.Doc,Spire XLS,Spire.PDF,Spire.BarCo

C#读写EXCEL(二)

C#读写EXCEL(二) 2010-08-25 14:50:42| 分类: 默认分类 | 标签: |举报 |字号大 中 小 订阅 用微信 “扫一扫” 将文章分享到朋友圈. 用易信 “扫一扫” 将文章分享到朋友圈. 下载LOFTER客户端 private void button1_click(object sender, system.eventargs e) { if(openfiledialog1.showdialog() == dialogresult.ok) { oledbdataadap

C#读写EXCEL(二) ZedGraph在Asp.net中的应用

C#读写EXCEL(二) 2010-08-25 14:50:42|  分类: 默认分类 |  标签: |举报 |字号大中小 订阅 用微信  “扫一扫” 将文章分享到朋友圈. 用易信  “扫一扫” 将文章分享到朋友圈. 下载LOFTER客户端 private void button1_click(object sender, system.eventargs e) { if(openfiledialog1.showdialog() == dialogresult.ok) { oledbdataad

【原创】.NET读写Excel工具Spire.Xls使用(2)Excel文件的控制

              本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/4288836.html .NET读写Excel工具Spire.Xls使用文章目录:http://www.cnblogs.com/asxinyu/p/4374032.html 前一篇文章:“.NET操作Excel利器Spire.Xls使用(1)入门介绍 ”给大家介绍了Spire.XLS的基本功能和一些比较.这篇文章将重点介绍C#操作Excel文件时,对Excel文件本身的相关

[转]用Python读写Excel文件

转自:http://www.gocalf.com/blog/python-read-write-excel.html#xlrd-xlwt 虽然天天跟数据打交道,也频繁地使用Excel进行一些简单的数据处理和展示,但长期以来总是小心地避免用Python直接读写Excel文件.通常我都是把数据保存为以TAB分割的文本文件(TSV),再在Excel中进行导入或者直接复制粘贴. 前段时间做一个项目,却不得不使用Python直接生成Excel文件,后来随着需求的变化,还要对已有的Excel文件进行读取.在