还真没做过winform的导出导入,今天上网百度了一下。结果---

所以还是我自己写个吧。之前做过web的,半搬半做就OK。

1添加引用:Aspose.Cells.dll(我们就叫工具包吧,可以从网上下载。关于它的操作我在“Aspose.Cells操作说明 中文版 下载 Aspose C# 导出Excel 实例”一文中的说。这里你暂时也可不理会它。)

Aspose.Cells.dll  和中文说明 下载地址: http://item.taobao.com/auction/item_detail-0db2-f9b1d99e6cb27d78ae9e6373a1529633.htm

即使没有安装office也能用噢,这是一个好强的大工具。

2编写Excel操作类

using System;
using System.Collections.Generic;
using System.Text;
using Aspose.Cells;
using System.Data;

public class AsposeExcel
{

private string outFileName = "";
     private string fullFilename = "";
     private Workbook book = null;
     private Worksheet sheet = null;

public AsposeExcel(string outfilename, string tempfilename)//导出构造数
     {
         outFileName = outfilename;
         book = new Workbook();
         // book.Open(tempfilename);这里我们暂时不用模板
         sheet = book.Worksheets[0];
     }
     public AsposeExcel(string fullfilename)//导入构造数
     {
         fullFilename = fullfilename;
         // book = new Workbook();
         //book.Open(tempfilename);
         //sheet = book.Worksheets[0];
     }

private void AddTitle(string title, int columnCount)
     {
         sheet.Cells.Merge(0, 0, 1, columnCount);
         sheet.Cells.Merge(1, 0, 1, columnCount);

Cell cell1 = sheet.Cells[0, 0];
         cell1.PutValue(title);
         cell1.Style.HorizontalAlignment = TextAlignmentType.Center;
         cell1.Style.Font.Name = "黑体";
         cell1.Style.Font.Size = 14;
         cell1.Style.Font.IsBold = true;

Cell cell2 = sheet.Cells[1, 0];
         cell1.PutValue("查询时间:" + DateTime.Now.ToLocalTime());
         cell2.SetStyle(cell1.Style);
     }

private void AddHeader(DataTable dt)
     {
         Cell cell = null;
         for (int col = 0; col < dt.Columns.Count; col++)
         {
             cell = sheet.Cells[0, col];
             cell.PutValue(dt.Columns[col].ColumnName);
             cell.Style.Font.IsBold = true;
         }
     }

private void AddBody(DataTable dt)
     {
         for (int r = 0; r < dt.Rows.Count; r++)
         {
             for (int c = 0; c < dt.Columns.Count; c++)
             {
                 sheet.Cells[r + 1, c].PutValue(dt.Rows[r][c].ToString());
             }
         }
     }
     //导出------------下一篇会用到这个方法
     public Boolean DatatableToExcel(DataTable dt)
     {
         Boolean yn = false;
         try
         {
             //sheet.Name = sheetName;

//AddTitle(title, dt.Columns.Count);
             //AddHeader(dt);
             AddBody(dt);

sheet.AutoFitColumns();
             //sheet.AutoFitRows();

book.Save(outFileName);
             yn = true;
             return yn;
         }
         catch (Exception e)
         {
             return yn;
             // throw e;
         }
     }

public DataTable ExcelToDatatalbe()//导入
     {
         Workbook book = new Workbook();
         book.Open(fullFilename);
         Worksheet sheet = book.Worksheets[0];
         Cells cells = sheet.Cells;
         //获取excel中的数据保存到一个datatable中
         DataTable dt_Import = cells.ExportDataTableAsString(0, 0, cells.MaxDataRow + 1, cells.MaxDataColumn + 1, false);
         // dt_Import.
         return dt_Import;
     }
}

3导出按钮事件中编写导出数据方法:

private void bt_excel_out_Click(object sender, EventArgs e)
         {
           
             SaveFileDialog saveFileDialog1 = new SaveFileDialog();//如果你直接从对话框中拉出来,就不用new了噢。

//设置文件类型
             saveFileDialog1.Filter = "导出Excel (*.xls)|*.xls|Word (*.doc)|*.doc";
             saveFileDialog1.FilterIndex = 2;
             saveFileDialog1.RestoreDirectory = true;
             saveFileDialog1.CreatePrompt = true;
             saveFileDialog1.Title = "导出文件保存路径";
             //saveFileDialog1.ShowDialog();
             //string strName = saveFileDialog1.FileName;

//设置默认文件类型显示顺序    
             //saveFileDialog1.FilterIndex = 2;

//保存对话框是否记忆上次打开的目录    
             saveFileDialog1.RestoreDirectory = true;

//点了保存按钮进入    
             if (saveFileDialog1.ShowDialog() == DialogResult.OK)
             {
                 //获得文件路径    
                 string localFilePath = saveFileDialog1.FileName.ToString();

//获取文件名,不带路径    
                 string fileNameExt = localFilePath.Substring(localFilePath.LastIndexOf("\\") + 1);

//获取文件路径,不带文件名    
                 string FilePath = localFilePath.Substring(0, localFilePath.LastIndexOf("\\"));

//给文件名前加上时间    
                 string newFileName = DateTime.Now.ToString("yyyyMMdd") + fileNameExt;

saveFileDialog1.FileName = FilePath + "\\" + newFileName;
                 System.IO.FileStream fs = (System.IO.FileStream)saveFileDialog1.OpenFile();//输出文件

                 //下面是导出数据到doc        导出到excel请看下一篇(发现没有AsposeExcel
类还没有用到呢,那正是导出到excel要用的)
                 StreamWriter writer = new StreamWriter(fs);
                 writer.Write("tttt");//这里就是你要导出到word文档的数据
                 writer.Flush();
                 writer.Close();
                 fs.Close();

}

}

C# winform 导出导入Excel/Doc 完整实例教程[网上看到的]的更多相关文章

  1. C# WinForm 导出导入Excel/Doc 完整实例教程[使用Aspose.Cells.dll]

    [csharp] view plain copy 1.添加引用: Aspose.Cells.dll(我们就叫工具包吧,可以从网上下载.关于它的操作我在“Aspose.Cells操作说明 中文版 下载 ...

  2. C# WinForm使用Aspose.Cells.dll 导出导入Excel/Doc 完整实例教程

    1.添加引用: Aspose.Cells.dll(我们就叫工具包吧,可以从网上下载.关于它的操作我在“Aspose.Cells操作说明 中文版 下载 Aspose C# 导出Excel 实例”一文中的 ...

  3. .Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) 通过MVC控制器导出导入Excel文件(可用于java SSH架构)

    .Net MVC  导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) [原文地址] 通过MVC控制器导出导入Excel文件(可用于java SSH架构)   public cl ...

  4. php利用PHPExcel类导出导入Excel用法

    PHPExcel类是php一个excel表格处理插件了,下面我来给大家介绍利用PHPExcel类来导入与导出excel表格的应用方法,有需要了解的朋友不防参考参考(PHPExcel自己百度下载这里不介 ...

  5. DevExpress XtraGrid 数据导出导入Excel

    // <summary> /// 导出按钮 /// </summary> /// <param name="sender"></param ...

  6. asp.net core导出导入excel

    使用NPOI导入导出excel,已经封装好Action可以直接调用 导出 效果图 使用方法 定义导出实体 class Student { public int Id { get; set; } pub ...

  7. 用PHPExcel导出导入Excel

    thinkPHP5.0框架 查询数据库调用Excel方法 public function exportlist(){ $orderModel = new OrderModel(); if($start ...

  8. asp.net Mvc Npoi 导出导入 excel

    因近期项目遇到所以记录一下: 首先导出Excel : 首先引用NPOI包 http://pan.baidu.com/s/1i3Fosux (Action一定要用FileResult) /// < ...

  9. PHPExcel导出导入excel、csv等格式数据

    <?php if(!defined('BASEPATH')) exit('No direct script access allowed'); //物资发料单明细 class Read_writ ...

随机推荐

  1. Js中的appenChild,insertBefore--createDocumentFragment

    平时项目中会有一些流程,或者是评论相关的东西,这些一般只会是在页面初次加载一部分,剩余部分搞一个更多的标签,当点击更多的时候,ajax请求把所有数据加载完(当然这里也有分页的实现方法,本篇不作讨论), ...

  2. Jquery Ajax调用aspx页面实例

    目前,我会的几种asp.net界面与后台代码交互方式有几种: 1.webform+服务器控件交互: 2.webform+jquery+ajax+一般处理程序交互: 3.webform+jquery+a ...

  3. oracle定时备份

    1.将如下代码复制到文本中,最后将文本后缀名称修改成XXX.bat 批处理文件: *********************************************************** ...

  4. iOS开发——常用字符串string相关方法和处理

    (持续更新中……) 1,四舍五入 2,剔除字符 3,拼接字符 4,字符个数和长度 5,字符串的比较 6,字符串的范围 7,字符串转Number类型

  5. C#下如何用NPlot绘制期货股票K线图(3):设计要显示的股票价格图表窗口并定义相应类的成员及函数

    [内容简介] 上一篇介绍了要显示K线图所需要的数据结构,及要动态显示K线图,需要动态读取数据文件必需的几个功能函数.本篇介绍要显示蜡烛图所用到的窗口界面设计及对应类定义.下面分述如下: [窗口界面] ...

  6. WPF动画之路径动画(3)

    XAML代码: <Window x:Class="路径动画.MainWindow" xmlns="http://schemas.microsoft.com/winf ...

  7. C#微信开发之旅--基本信息的回复

    上一篇说到配置和验证<C#微信开发之旅--准备阶段> 下面来实现一下简单的信息回复. 也就是接收XML,返回XML 可以去看下微信开发文档的说明:http://mp.weixin.qq.c ...

  8. linux进程间通信--有名管道

    有名管道 只有当一个库函数失败时,errno才会被设置.当函数成功运行时,errno的值不会被修改.这意味着我们不能通过测试errno的值来判断是否有错误存在.反之,只有当被调用的函数提示有错误发生时 ...

  9. .net生成随机验证码图片

    /// <summary> /// 自定义图片验证码函数 /// 该函数将生成一个图片验证码,并将生成的code存放于Session["VerifyCode"]变量内. ...

  10. 几个常用方法有效优化ASP.NET的性能

    一. 数据库访问性能优化 1),数据库的连接和关闭 访问数据库资源需要创建连接.打开连接和关闭连接几个操作.这些过程需要多次与数据库交换信息以通过身份验证,比较耗费服务器资源.ASP.NET中提供了连 ...