[WinForm]dataGridView导出到EXCEL
方法一:
- SaveFileDialog dlg = new SaveFileDialog();
- dlg.Filter = "Execl files (*.xls)|*.xls";
- dlg.FilterIndex = 0;
- dlg.RestoreDirectory = true;
- dlg.CreatePrompt = true;
- dlg.Title = "保存为Excel文件";
- dlg.FileName = "不合格记录";//保存的Excel名字
- if (dlg.ShowDialog() == DialogResult.OK)
- {
- Stream myStream;
- myStream = dlg.OpenFile();
- StreamWriter sw = new StreamWriter(myStream, System.Text.Encoding.GetEncoding(-0));
- string columnTitle = "";
- try
- {
- //写入列标题
- for (int i = 0; i < dgv.ColumnCount; i++)
- {
- if (i > 0)
- {
- columnTitle += "\t";
- }
- columnTitle += dgv.Columns[i].HeaderText;
- }
- sw.WriteLine(columnTitle);
- //写入列内容
- for (int j = 0; j < dgv.Rows.Count; j++)
- {
- string columnValue = "";
- for (int k = 0; k < dgv.Columns.Count; k++)
- {
- if (k > 0)
- {
- columnValue += "\t";
- }
- if (dgv.Rows[j].Cells[k].Value == null)
- columnValue += "";
- else
- columnValue += dgv.Rows[j].Cells[k].Value.ToString().Trim();
- }
- sw.WriteLine(columnValue);
- }
- sw.Close();
- myStream.Close();
- }
- catch (Exception e)
- {
- MessageBox.Show(e.ToString());
- }
- finally
- {
- sw.Close();
- myStream.Close();
- }
- }
方法二:包含图片
- Microsoft.Office.Interop.Excel.Application Myexcel = new Microsoft.Office.Interop.Excel.Application();
- if (Myexcel == null)
- {
- return;
- }
- Microsoft.Office.Interop.Excel._Workbook xBk;
- xBk = Myexcel.Application.Workbooks.Add(true);
- Microsoft.Office.Interop.Excel._Worksheet xSt;
- xSt = (Microsoft.Office.Interop.Excel._Worksheet)xBk.ActiveSheet;
- //设置标题等
- string Title = null;
- Title = DateTime.Now.ToLongDateString() + "报价表";
- xSt.Name = Title;
- //报表的格式设置
- //xSt.Cells[1, 6] = Title;
- // xSt.get_Range(Myexcel.Cells[1, 6], Myexcel.Cells[1, 6]).HorizontalAlignment = Microsoft.Office.Interop.Excel.XlVAlign.xlVAlignCenter;//设置标题格式为居中对齐
- // xSt.get_Range(Myexcel.Cells[1, 6], Myexcel.Cells[1, 6]).Font.Bold = true;
- //xSt.get_Range(Myexcel.Cells[1, 6], Myexcel.Cells[1, 6]).Font.Size = 20;
- xSt.Cells[1, 1] = "品号";
- xSt.Cells[1, 2] = "品名";
- xSt.Cells[1, 3] = "客户品号";
- xSt.Cells[1, 4] = "图片";
- xSt.Cells[1, 5] = "客户编码";
- xSt.Cells[1, 6] = "客户名称";
- xSt.Cells[1, 7] = "数量";
- xSt.Cells[1, 8] = "币种";
- xSt.Cells[1, 9] = "汇率";
- xSt.Cells[1, 10] = "原币单价";
- xSt.Cells[1, 11] = "原币总价";
- xSt.Cells[1, 12] = "本币单价";
- xSt.Cells[1, 13] = "本币总价";
- xSt.Cells[1, 14] = "创建时间";
- //下面是用循环把datagridview中的内容写到excel
- for (int rowIndex = 0; rowIndex < this.dgvQuotation.Rows.Count; rowIndex++)
- {
- int colIndex = 0;
- for (colIndex = 1; colIndex <= dgvQuotation.ColumnCount; colIndex++)
- {
- String value = null;
- if (dgvQuotation.Rows[rowIndex].Cells[colIndex - 1].Value != null)
- {
- value = dgvQuotation.Rows[rowIndex].Cells[colIndex - 1].Value.ToString();
- if (dgvQuotation.Columns[colIndex - 1].Name == "图片") //处理
- {
- Image img;
- //如果是二进制形式:
- //MemoryStream ms = new MemoryStream((byte[])dgvQuotation.Rows[rowIndex].Cells[colIndex - 1].Value);
- if (File.Exists(@"D:\产品图片\" + dgvQuotation.Rows[rowIndex].Cells[0].Value.ToString() + ".jpg"))
- {
- //需要判断是否存在图片
- img = Image.FromFile(@"D:\产品图片\" + dgvQuotation.Rows[rowIndex].Cells[0].Value.ToString() + ".jpg");//双引号里是图片的路径
- }
- else
- {
- //需要判断是否存在图片
- img = Image.FromFile(@"D:\产品图片\LOGO.jpg");//双引号里是图片的路径
- }
- //Image img = Image.FromStream(ms);
- //路径
- // Image img = GetImage(value);
- string tmpName = tmpPath + "\\temp" + rowIndex + ".bmp";
- img.Save(tmpName);
- string cellAddr = (GetAddress(rowIndex + 4, colIndex));
- Microsoft.Office.Interop.Excel.Range range = (Microsoft.Office.Interop.Excel.Range)xSt.get_Range(cellAddr, Type.Missing);
- float left = float.Parse(range.Left.ToString());
- float top = float.Parse(range.Top.ToString());
- float width = float.Parse(range.Width.ToString());
- float height = float.Parse(range.Height.ToString());
- xSt.Shapes.AddPicture(tmpName, MsoTriState.msoFalse, MsoTriState.msoTrue, left, top, width, height);
- //xSt.Shapes.AddPicture(tmpName, MsoTriState.msoFalse, MsoTriState.msoTrue, left, top, 200, 200);
- continue;
- }
- }
- xSt.Cells[rowIndex + 4, colIndex] = value;
- }
- }
- //后台处理
- //用户无法看到
- Myexcel.Visible = false;
- //允许打开对话框保存文件
- Myexcel.DisplayAlerts = true;
- // xBk.Close(true, "D:\\1.xls", null);
- xSt = null;
- xBk = null;
- Myexcel.Quit();
- System.Runtime.InteropServices.Marshal.ReleaseComObject(Myexcel);
- Myexcel = null;
[WinForm]dataGridView导出到EXCEL的更多相关文章
- winform DataGridView 导出到Excel表格 分类: WinForm 2014-07-04 10:48 177人阅读 评论(0) 收藏
public bool ExportDataGridview(DataGridView gridView) { if (gridView.Rows.Count ...
- DataGridView导出到Excel的三个方法
#region DataGridView数据显示到Excel /// <summary> /// 打开Excel并将DataGridView控件中数据导出到Excel /// </s ...
- c# datagridview导出到excel【转载】
c# datagridview导出到excel[转载] http://hi.baidu.com/weizier/blog/item/8212caea1123b4d6d439c9fe.html 本作者使 ...
- C# - VS2019 DataGridView导出到Excel的三种方法
//原文出处:http://www.yongfa365.com/Item/DataGridViewToExcel.html 1 #region DataGridView数据显示到Excel /// & ...
- Winform 中 dataGridView 导出到Excel中的方法总结
最近,在做CS端数据导出到Excel中时网上找了很多代码感觉都不是自己想要的,通过自己的整理归纳得到一个比较通用的方法,就给大家分享一下: 该方法需要用到两个参数(即对象),一个 DataGridV ...
- 【转】c# winform DataGridView导出数据到Excel中,可以导出当前页和全部数据
准备工作就是可以分页的DataGridView,和两个按钮,一个用来导出当前页数据到Excel,一个用来导出全部数据到Excel 没有使用SaveFileDialog,但却可以弹出保存对话框来 先做导 ...
- winform datagridview 导出excel
using System;using System.Collections.Generic;using System.Text;using System.IO;using Microsoft.Offi ...
- WinForm中DataGridView导出为Excel(快速版)
public static void ExportExcel(DataGridView myDGV, string fileName) { string saveFileName = fileName ...
- DataGridView 导出到Excel
#region 导出四个表格到Excel /// <summary> /// 导出四个表格到Excel /// </summary> /// <param name=&q ...
随机推荐
- Android项目实战(四十五):Usb转串口通讯(CH34xUARTDriver)
需求为:手机usb接口插入一个硬件,从硬件上获取数据 例如:手机usb插入硬件A,A通过蓝牙通讯获取设备a.b的数据,作为中转站(可以做些数据处理)将数据(设备a.b产生的)传给手机程序. 设备A也可 ...
- jQuery 遍历 – 同胞(siblings)
同胞拥有相同的父元素. 通过 jQuery,您能够在 DOM 树中遍历元素的同胞元素. 在 DOM 树中水平遍历 有许多有用的方法让我们在 DOM 树进行水平遍历: siblings() next() ...
- MongoDB 条件操作符
描述 条件操作符用于比较两个表达式并从mongoDB集合中获取数据. 在本章节中,我们将讨论如何在MongoDB中使用条件操作符. MongoDB中条件操作符有: (>) 大于 - $gt (& ...
- linux:如何指定进程运行的CPU
coolshell最新的文章<性能调优攻略>在"多核CPU调优"章节,提到"我们不能任由操作系统负载均衡,因为我们自己更了解自己的程序,所以,我们可以手动地为 ...
- 《Shazam It! Music Recognition Algorithms, Fingerprinting, and Processing》译文
最近看到一篇老外写的博客,简单介绍了shazam的工作原理.图非常好,所以就把它翻译成中文,希望对搞听歌识曲的人有帮助. 你可能遇到这样的场景:在酒吧或者餐厅听到你非常熟悉的歌,也许你曾经听过无数次, ...
- ubuntu切换java版本
众所周知,ubuntu经常需要安装不同的java版本,他们之间的切换就是一个很大的问题 1.Chose another Java loader: sudo update-alternatives -- ...
- OpenMP与MPI联合编程
研究一下如何一起使用mpi和openmp 先上程序: #include <stdio.h> #include <stdlib.h> #ifdef _OPENMP #includ ...
- JDBC编程-事务编程(四)
事务的概念 事务的概念在我看来是指的是一组sql序列,这个序列是一块执行的单位,要么全部执行,要不全部执行,这样可以很好的对数据库进行并发控制. 因为数据库是多个用户都可以同时操作的,如果多个用户同时 ...
- 自己写一个网页版的Markdown实时编辑器
这几天忙着使用Python+Django+sqlite 搭建自己的博客系统,但是单纯的使用H5的TextArea,简直太挫了有木有.所以,就想模仿一下人家内嵌到网页上的Markdown编辑器,从而让自 ...
- UNIX网络编程——tcp流协议产生的粘包问题和解决方案
我们在前面曾经说过,发送端可以是一K一K地发送数据,而接收端的应用程序可以两K两K地提走数据,当然也有可能一次提走3K或6K数据,或者一次只提走几个字节的数据,也就是说,应用程序所看到的数据是一个整体 ...