winfrom导出DataGridView为Excel方法

声明:此方法需要电脑安装Excel软件

需要类库:Microsoft.Office.Interop.Excel.dll 可百度自行下载

方法代码:

        /// <summary>/// 导出exc/// </summary>/// <param name="dataGridView"></param>///  <param name="name">文件名字</param>public static void Import(DataGridView dataGridView,string name){string fileName = name;string saveFileName = "";SaveFileDialog saveDialog = new SaveFileDialog();saveDialog.DefaultExt = "xlsx";saveDialog.Filter = "Excel文件|*.xlsx";saveDialog.FileName = fileName;var alert= saveDialog.ShowDialog();if (alert!=DialogResult.OK){return;}saveFileName = saveDialog.FileName;Microsoft.Office.Interop.Excel.Application xlApp =new Microsoft.Office.Interop.Excel.Application();if (xlApp == null){MessageBox.Show("无法创建Excel对象,您的电脑可能未安装Excel");return;}Microsoft.Office.Interop.Excel.Workbooks workbooks = xlApp.Workbooks;Microsoft.Office.Interop.Excel.Workbook workbook =workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);Microsoft.Office.Interop.Excel.Worksheet worksheet =(Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[1];//取得sheet1 //写入标题             for (int i = 0; i < dataGridView.ColumnCount; i++){ worksheet.Cells[1, i + 1] = dataGridView.Columns[i].HeaderText; }//写入数值for (int r = 0; r < dataGridView.Rows.Count; r++){for (int i = 0; i < dataGridView.ColumnCount; i++){worksheet.Cells[r + 2, i + 1] = dataGridView.Rows[r].Cells[i].Value;}System.Windows.Forms.Application.DoEvents();}worksheet.Columns.EntireColumn.AutoFit();//列宽自适应MessageBox.Show("导出成功", "提示", MessageBoxButtons.OK);if (saveFileName != ""){try{workbook.Saved = true;workbook.SaveCopyAs(saveFileName);  //fileSaved = true;                 
                }catch (Exception ex){MessageBox.Show("导出文件时出错,文件可能正被打开!\n" + ex.Message);}}xlApp.Quit();GC.Collect();//强行销毁           }

 

转载于:https://www.cnblogs.com/Angel-szl/p/10525028.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/483952.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机网络——因特网的接入技术

因特网接入与ISP ISP&#xff1a;Internet服务供应商&#xff0c;为接入Internet提供基本的服务 一、模拟拨号 早期使用调制解调器&#xff08;Modem&#xff09;和常规的语音级电话线路早期使用最为广泛&#xff0c;最大带宽56Kb/s【下一首歌差不多要30分钟、上网就不能打电…

谈人工智能:深度学习对老牌AI

来源&#xff1a;李晓榕科学网博客链接地址&#xff1a;http://blog.sciencenet.cn/blog-687793-1300748.html学&#xff1a;学生&#xff0c;教&#xff1a;教师&#xff0c;李&#xff1a;李晓榕李&#xff1a;三代人工智能都各有所本、各有所倚&#xff0c;也就各有所偏&…

OpenGL之Phong光照模型和Blinn-Phong光照模型的局限性、OpenGL光照参数设置与光照模式

一、相关概念 1.1 Phong、Blinn-Phong光照模型是一种简单光照模型&#xff0c;它仅考虑了光源直接照射的效果&#xff0c;没有考虑非直接光照的效果。如下直接光照与间接光照。 1.2 上述模型在考虑间接光照&#xff08;环境光&#xff09;时&#xff0c;采用的是一个常数来表…

【Codeforces 1096D】Easy Problem

【链接】 我是链接,点我呀:) 【题意】 让你将一个字符串删掉一些字符。 使得字符串中不包含子序列"hard" 删掉每个字符的代价已知为ai 让你求出代价最小的方法. 【题解】 设dp[i][j]表示前i个字符,已经和"hard"匹配前j个的最小花费。 对于dp[i][j] 对s[i…

OpenGL之图形流水线中的光照计算、明暗处理

1.1 光照计算发生在图形流水线的Vertex Operations中&#xff0c;只计算每个顶点的颜色&#xff0c;而三角形内部的点的颜色在Fragment Operations阶段通计算&#xff0c;这样效率高&#xff0c;因为像素的数量远远大于顶点的数量。 1.2 计算三角形内每个像素的颜色的过程&am…

教学5层网络体系结构——分层之后数据的发送和接收

协议分层后数据发送过程 发送方层层封装 接收方层层解封装 唯一加尾部的是数据链路层 思考 发送方某层封装完如何知道该交给哪个下层封装&#xff1f; 应用层选择传输层由应用程序决定&#xff0c;传输层选择网络层由固定的搭配&#xff0c;例如因特网只有IP协议&#x…

从视觉系统的原理入手 破解VR眩晕症

来源&#xff1a;EETimes编译&#xff1a;科技行者虚拟现实技术近年来迎来一波快速发展&#xff0c;适用范围也扩展到更多领域&#xff0c;引得众多老牌巨头纷纷参与。然而&#xff0c;VR技术自身仍存在一些极难解决的缺陷&#xff0c;如果无法攻克&#xff0c;技术的进一步普及…

小组会谈(2019.3.14)

一&#xff1a;会议主题 1.确定项目的立题 2.讨论需要实现的功能 3.确定小组成员之间的分工和完成各自任务的期限 二&#xff1a;会议地点 逸夫楼C座一楼 三&#xff1a;会议时间 2018年3月14日10&#xff1a;00--11&#xff1a;20 四&#xff1a;会议内容 1.项目的立题&#x…

TinyXml库的用法之xml文件节点遍历与节点删除

tinyxml是一个C++编写的轻量级xml文件解析库,只需要导入tinyxml.h头文件就可以进行xml文件的操作。 文章目录 前言一、xml文件解析二、xml文件操作总结前言 xml文件在软件设计中被广泛用来进行数据交换,经常需要对xml文件进行操作,本文主要简单介绍对xml文件的节点进行遍历…

应用层相关概念

一、应用层概述 1、应用层协议基本概念 应用层的功能 应用层协议定义了应用程序需交换的报文、所需采取的动作和最终通信数据的应用应用层位于协议栈的最高层次应用层协议提供不同主机之间进程与进程之间的通信用户代理实现应用层协议 套接字 IP端口号&#xff0c;唯一确定…

迎来智能数据分析的新时代

来源&#xff1a;知乎(ID:熊墨淼)最近两星期&#xff08;7月15日&#xff0c;7月22日)&#xff0c;《自然》杂志连续发表两篇DeepMind写的用人工智能的方法预测蛋白质三维结构的文章和NIH Director Francis Collins 写的博客 &#xff02;Artificial Intelligence Accurately P…

2019春季第三周作业

2019年春季学期第三周作业基础作业 本周没上课&#xff0c;但是请大家不要忘记学习。 本周请大家完成上周挑战作业的第一部分&#xff1a;给定一个整数数组(包含正负数)&#xff0c;找到一个具有最大和的子数组&#xff0c;返回其最大的子数组的和。 例如&#xff1a;[1, -2, 3…

DNS域名系统详解

一、分层次的域名结构 顶级域名、 二级域名、 三级域名、 四级域名 二、因特网的域名结构 因特网采用了层次树状结构的命名方法&#xff0c;称为域名&#xff0c;如&#xff1a;www.jxnu.edu.cn 三级域名&#xff1a;如www表示万维网 二级域名&#xff1a;如jxnu表示江西师…

侯世达:让机器学习思考的人

图源&#xff1a;GREG RUFFING来源&#xff1a;利维坦文&#xff1a;James Somers原文&#xff1a;www.theatlantic.com/magazine/archive/2013/11/the-man-who-would-teach-machines-to-think/309529/译文原载&#xff1a;《新知》杂志侯世达&#xff08;Douglas Hofstadter&a…

日记——2019-03-12

感遇&#xff08;其一&#xff09; 张九龄 兰叶春葳蕤&#xff0c;桂华秋皎洁。 欣欣此生意&#xff0c;自尔为佳节。 谁知林栖者&#xff0c;闻风坐相悦。 草木有本心&#xff0c;何求美人折&#xff1f; 我的爱人快乐而且善良&#xff0c;但是不容易&#xff0c;遇见——庞德…

www万维网和HTTP协议

万维网的相关概念 万维网的客户端程序 浏览器&#xff1a;IE、firefox、chrome 万维网的服务器端软件 IIS&#xff0c;Tomcat、Apache 万维网的模式 采用C/S模式 Web页面 由文字、图片、声音、视频等多种对象组成 HTTP协议 Web页面传输方式 如何标志分布在因特网上的…

游戏中应用强化学习技术,目的就是要打败人类玩家?

来源&#xff1a;AI前线作者&#xff1a;凌敏采访嘉宾&#xff1a;黄鸿波2016 年&#xff0c;DeepMind 公司开发的 AlphaGo 4:1 大胜韩国著名棋手李世石&#xff0c;成为第一个战胜围棋世界冠军的人工智能机器人&#xff0c;一时风头无两。AlphaGo 的巨大成功开启了“人工智能元…

HTTP报文的格式

一、HTTP请求报文的格式 两个回车换行表示首部的结尾注意&#xff1a;HTTP协议首部使用ASCII码作为编码方式HTTP请求报文提交表单时会包含数据 二、HTTP响应报文格式

laravel的重定向

Route::get("redirect1", function () { // redirct的三种写法 // return redirect()->route("testRedirect");    //路由命名的使用方式 route("name") laravel内置函数 // return redirect(/redirect2);       //lara…

Transformer走下神坛?南加州大学教授:想解决常识问题,神经网络不是答案

来源&#xff1a;nextgov转自&#xff1a;新智元编辑&#xff1a;LRS如果说人工智能和真正的人脑之间的差距&#xff0c;那最重要的就是机器缺乏生活中的常识。一切貌似合理、理所当然的事物在计算机眼中都是不可理解的。计算机不知道「柠檬是酸的」&#xff0c;「只有成熟的香…