窗体下的Excel导入问题

本文介绍了C#窗体下处理Excel导入和导出的常见步骤及方法。首先,详细阐述了Excel导入的四个步骤,包括检查数据库、清空或导入数据,以及使用OleDb进行数据读取和导入。接着,展示了如何实现Excel模板的下载,通过SaveFileDialog对话框让用户选择保存位置。提供的代码示例展示了如何通过连接字符串和ADO.NET操作Excel文件,以及处理文件复制以完成模板下载。这些操作在‘金融高等专科院校招生系统’中得到应用。

1.Excel的导入问题通常分为四步,第一步:看数据库中是否有相应的数据;第二步:有的话,将数据进行清空;没有的话,直接导入;

第三步:从Excel表格中将数据读出来读在Datatable表中;第四步:将Datatable表中的数据导入数据库;

对于窗体来说一个比较好的读Excel的方法如下,也不会存在版本的问题。

//sql语句读取Excel
        public static DataTable ReadExcel(string filePath)
        {
            try
            {
                string strConn;
                //此连接可以操作.xls与.xlsx文件 (支持Excel2003 和 Excel2007 的连接字符串)
                //"HDR=yes;"是说Excel文件的第一行是列名而不是数据,"HDR=No;"正好与前面的相反
                //"IMEX=1 "如果列中的数据类型不一致,使用"IMEX=1"可必免数据类型冲突。
                strConn = "Provider=Microsoft.Ace.OleDb.12.0;data source=" + filePath + ";Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'"; 
                OleDbConnection OleConn = new OleDbConnection(strConn);
                OleConn.Open();
                String sql = "SELECT * FROM  [Sheet1$]";//可是更改Sheet名称,比如sheet2,等等 


                OleDbDataAdapter OleDaExcel = new OleDbDataAdapter(sql, OleConn);
                DataSet OleDsExcle = new DataSet();
                OleDaExcel.Fill(OleDsExcle, "Sheet1");
                OleConn.Close();


                return OleDsExcle.Tables["Sheet1"];
            }
            catch (Exception err)
            {
                MessageBox.Show("数据绑定Excel失败!失败原因:" + err.Message, "提示信息",
                    MessageBoxButtons.OK, MessageBoxIcon.Information);
                return null;
            }
        }

2.对于“下载模板”来说,也可以将其理解为将模板放在客户端(client),进行另存为的问题,这样比较简便。

 //下载模板
        private void btn_xzmb_Click(object sender, EventArgs e)
        {
            SaveFileDialog sfd = new SaveFileDialog();
            //设置文件类型
            sfd.FileName = "招生计划模板与说明—2017";
            sfd.Filter = "xlsx文件(*.xlsx)|*.xlsx|xls文件(*.xls)|*.xls";
            string path = System.Windows.Forms.Application.StartupPath + "\\模板\\model.xlsx";
            if (!System.IO.File.Exists(path))
            {
                MessageBox.Show("下载模板失败!");
                return;
            }
            //点了保存按钮进入
            if (sfd.ShowDialog() == DialogResult.OK)
            {
                //获得文件路径
                string localFilePath = sfd.FileName.ToString();
                if (sfd.FileName == "")
                {
                    MessageBox.Show("请输入文件名!", "警告", MessageBoxButtons.OK, MessageBoxIcon.Information);
                    return;
                }
                else
                {
                    System.IO.File.Copy(path, localFilePath, true);
                    MessageBox.Show("下载模板成功!");
                }
            }
        }

https://zhidao.baidu.com/question/63918657.html
为操作Excel的方法
http://blog.youkuaiyun.com/g710710/article/details/21166453
解决  C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致

以上都是在做“金融高等专科院校招生系统”的操作。

【事件触发一致性】研究多智能体网络如何通过分布式事件驱动控制实现有限时间内的共识(Matlab代码实现)内容概要:本文围绕多智能体网络中的事件触发一致性问题,研究如何通过分布式事件驱动控制实现有限时间内的共识,并提供了相应的Matlab代码实现方案。文中探讨了事件触发机制在降低通信负担、提升系统效率方面的优势,重点分析了多智能体系统在有限时间收敛的一致性控制策略,涉及系统模型构建、触发条件设计、稳定性与收敛性分析等核心技术环节。此外,文档还展示了该技术在航空航天、电力系统、机器人协同、无人机编队等多个前沿领域的潜在应用,体现了其跨学科的研究价值和工程实用性。; 适合人群:具备一定控制理论基础和Matlab编程能力的研究生、科研人员及从事自动化、智能系统、多智能体协同控制等相关领域的工程技术人员。; 使用场景及目标:①用于理解和实现多智能体系统在有限时间内达成一致的分布式控制方法;②为事件触发控制、分布式优化、协同控制等课题提供算法设计与仿真验证的技术参考;③支撑科研项目开发、学术论文复现及工程原型系统搭建; 阅读建议:建议结合文中提供的Matlab代码进行实践操作,重点关注事件触发条件的设计逻辑与系统收敛性证明之间的关系,同时可延伸至其他应用场景进行二次开发与性能优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值