当前位置: 首页 > news >正文

C# EXCEL 导入导出类(OLEDB的方式)

 
public static class ExcelHelper
    {


        #region 导入


        /// <summary>
        /// 导入EXCEL(默认的sheet)
        /// </summary>
        /// <param name="fileName"></param>
        /// <returns></returns>
        public static System.Data.DataTable ImpExcelDt(string fileName) 
        {
            return ImpExcelDt(fileName, "Sheet1");
        }


        /// <summary>
        /// excel 导入
        /// </summary>
        /// <param name="fileName"></param>
        /// <param name="sheetName"></param>
        /// <returns></returns>
        public static System.Data.DataTable ImpExcelDt(string fileName, string sheetName)
        {
            try
            {
                if (!File.Exists(fileName)) 
                {
                    return null;
                }
                string strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + fileName + ";Extended Properties='Excel 8.0;HDR=False;IMEX=1'";
                OleDbConnection myConn = new OleDbConnection(strCon);
                string strCom = " SELECT * FROM [" + sheetName + "$] ";
                myConn.Open();
                OleDbDataAdapter myCommand = new OleDbDataAdapter(strCom, myConn);
                DataSet myDataSet = new DataSet();
                myCommand.Fill(myDataSet, "[" + sheetName + "$]");
                myConn.Close();


                System.Data.DataTable dt = myDataSet.Tables[0];
                return dt;
            }
            catch(Exception ex)
            {
                throw ex;
            }
        }


        #endregion


        #region 导出到EXCEL


        /// <summary>
        /// 将数据导出到指定的Excel文件中
        /// </summary>
        /// <param name="listView">System.Windows.Forms.ListView,指定要导出的数据源</param>
        /// <param name="destFileName">指定目标文件路径</param>
        /// <param name="tableName">要导出到的表名称</param>
        /// <param name="overWrite">指定是否覆盖已存在的表</param>
        /// <returns>导出的记录的行数</returns>
        public static int ExportToExcel(System.Data.DataTable dt, string destFileName, string tableName)
        {
            if (File.Exists(destFileName)) 
            {
                File.Delete(destFileName);
            }
            //得到字段名
            string szFields = "";
            string szValues = "";
            for (int i = 0; i < dt.Columns.Count; i++)
            {
                szFields += "[" + dt.Columns[i] + "],";
            }
            szFields = szFields.TrimEnd(',');
            //定义数据连接
            OleDbConnection connection = new OleDbConnection();
            connection.ConnectionString = GetConnectionString(destFileName);
            OleDbCommand command = new OleDbCommand();
            command.Connection = connection;
            command.CommandType = CommandType.Text;
            //打开数据库连接
            try
            {
                connection.Open();
            }
            catch
            {
                throw new Exception("目标文件路径错误。");
            }
            //创建数据库表
            try
            {
                command.CommandText = GetCreateTableSql("[" + tableName + "]", szFields.Split(','));
                command.ExecuteNonQuery();
            }
            catch (Exception ex)
            {
                //如果允许覆盖则删除已有数据
                throw ex;
            }
            try
            {
                //循环处理数据------------------------------------------
                int recordCount = 0;
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    szValues = "";
                    for (int j = 0; j < dt.Columns.Count; j++)
                    {
                            szValues += "'" + dt.Rows[i][j] + "',";
                       
                    }
                    szValues = szValues.TrimEnd(',');
                    //组合成SQL语句并执行
                    string szSql = "INSERT INTO [" + tableName + "](" + szFields + ") VALUES(" + szValues + ")";
                    command.CommandText = szSql;
                    recordCount += command.ExecuteNonQuery();
                }
                connection.Close();
                return recordCount;
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        //得到连接字符串
        private static String GetConnectionString(string fullPath)
        {
            string szConnection;
            szConnection = "Provider=Microsoft.JET.OLEDB.4.0;Extended Properties=Excel 8.0;data source=" + fullPath;
            return szConnection;
        }


        //得到创建表的SQL语句
        private static string GetCreateTableSql(string tableName, string[] fields)
        {
            string szSql = "CREATE TABLE " + tableName + "(";
            for (int i = 0; i < fields.Length; i++)
            {
                szSql += fields[i] + " VARCHAR(200),";
            }
            szSql = szSql.TrimEnd(',') + ")";
            return szSql;
        }


        #endregion
    }

相关文章:

  • 相声:我要谈恋爱
  • C# 操作EXCEL样式 示例 --生成EXCEL审计表
  • C# 操作EXCEL
  • 新浪评出2008年度IT博客
  • c# 隐藏已打开的窗口,打开登陆窗口
  • 十个常用的S60手机软件
  • VB 操作ACCESS 实例 练习题--ATM取款机 代码段
  • 十大经典Java手机游戏 Top Ten Best Java Mobile Games
  • chrome下使用jquery中的load函数无效问题
  • C# 操作配置文件 App.config
  • iPhone入华情变 谁动了中移动的苹果?
  • C# 托盘程序
  • C# 托盘程序 实例 双击显示窗体,最小化到托盘
  • Myeclipse6.0的破解方法
  • 免费的网页原型制作工具
  • 深入了解以太坊
  • ES6指北【2】—— 箭头函数
  • [数据结构]链表的实现在PHP中
  • 2018一半小结一波
  • java 多线程基础, 我觉得还是有必要看看的
  • Java面向对象及其三大特征
  • Java知识点总结(JavaIO-打印流)
  • JDK9: 集成 Jshell 和 Maven 项目.
  • JS学习笔记——闭包
  • Netty 框架总结「ChannelHandler 及 EventLoop」
  • Webpack 4 学习01(基础配置)
  • 大数据与云计算学习:数据分析(二)
  • 力扣(LeetCode)357
  • 每个JavaScript开发人员应阅读的书【1】 - JavaScript: The Good Parts
  • 世界上最简单的无等待算法(getAndIncrement)
  • 我与Jetbrains的这些年
  • Oracle Portal 11g Diagnostics using Remote Diagnostic Agent (RDA) [ID 1059805.
  • puppet连载22:define用法
  • $L^p$ 调和函数恒为零
  • (C#)Windows Shell 外壳编程系列4 - 上下文菜单(iContextMenu)(二)嵌入菜单和执行命令...
  • (保姆级教程)Mysql中索引、触发器、存储过程、存储函数的概念、作用,以及如何使用索引、存储过程,代码操作演示
  • (附源码)springboot高校宿舍交电费系统 毕业设计031552
  • (附源码)springboot社区居家养老互助服务管理平台 毕业设计 062027
  • (附源码)计算机毕业设计SSM保险客户管理系统
  • (黑客游戏)HackTheGame1.21 过关攻略
  • (牛客腾讯思维编程题)编码编码分组打印下标(java 版本+ C版本)
  • (企业 / 公司项目)前端使用pingyin-pro将汉字转成拼音
  • (十) 初识 Docker file
  • (太强大了) - Linux 性能监控、测试、优化工具
  • (原)本想说脏话,奈何已放下
  • (转) SpringBoot:使用spring-boot-devtools进行热部署以及不生效的问题解决
  • (转)ORM
  • (转)总结使用Unity 3D优化游戏运行性能的经验
  • *Django中的Ajax 纯js的书写样式1
  • .NET Core/Framework 创建委托以大幅度提高反射调用的性能
  • .net 中viewstate的原理和使用
  • .NET序列化 serializable,反序列化
  • .net中调用windows performance记录性能信息
  • [ web基础篇 ] Burp Suite 爆破 Basic 认证密码
  • [ 云计算 | AWS 实践 ] Java 如何重命名 Amazon S3 中的文件和文件夹