NPOI 教程---读写Excel

简介: 博客链接: http://www.cnblogs.com/atao/category/209358.html http://blog.csdn.net/zhumi/article/details/49076 http://tonyqus.

博客链接:

http://www.cnblogs.com/atao/category/209358.html

http://blog.csdn.net/zhumi/article/details/49076

http://tonyqus.sinaapp.com/tutorial

官网:http://npoi.codeplex.com/

NPOI官方网站:http://www.npoi.info/npoi2tutorial (教程系列)

 

示例:

using ExcelManager.Model;
using NPOI.HSSF.UserModel;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Windows.Forms;

namespace ExcelManager.Helper
{
    public class ExportHelper
    {
        /// <summary>
        /// 导出入库表格
        /// </summary>
        /// <param name="List"></param>
        public static void ExportStorage(List<UserModel> List)
        {
            if (List.Count == 0)
            {
                return;
            }

            try
            {
                
                HSSFWorkbook hssfworkbook = new HSSFWorkbook();

                HSSFSheet sheet = (HSSFSheet)hssfworkbook.CreateSheet("Sheet1");
                sheet.SetColumnWidth(0, 256 * 15);//256*legth 设置列宽
                sheet.SetColumnWidth(1, 256 * 30);
                
                //创建列名
                HSSFRow rowHeader = (HSSFRow)sheet.CreateRow(0);
                rowHeader.CreateCell(0).SetCellValue("编号");
                rowHeader.CreateCell(1).SetCellValue("姓名");
                
                //创建表头
                HSSFRow rowContent = null;
                int rowIndex = 1;
                foreach (var item in List)
                {
                    rowContent = (HSSFRow)sheet.CreateRow(rowIndex++);
                    rowContent.CreateCell(0).SetCellValue(item.ID);
                    rowContent.CreateCell(1).SetCellValue(item.Name); 
                }

                SaveExcel("测试", hssfworkbook);
            }
            catch (Exception ex)
            {
                LogUtil.Log("导出异常:" + ex.ToString());
                MessageBox.Show("导出失败");
            }
        }

        #region 保存文件
        /// <summary>
        /// 保存文件
        /// </summary>
        /// <param name="fileNamePrefix">文件名前缀</param>
        /// <param name="hssfworkbook">HSSFWorkbook</param>
        private static void SaveExcel(string fileNamePrefix, HSSFWorkbook hssfworkbook)
        {
            SaveFileDialog dialog = new SaveFileDialog();
            dialog.Filter = "Excel 工作表 (*.xls)|*.xls";
            dialog.RestoreDirectory = true;
            dialog.FileName = fileNamePrefix + "_" + DateTime.Now.ToString("yyyyMMdd_HHmmss");
            if (dialog.ShowDialog() == DialogResult.OK)
            {
                string path = dialog.FileName.ToString();
                using (FileStream file = new FileStream(path, FileMode.Create))
                {
                    hssfworkbook.Write(file);
                }
                MessageBox.Show("导出完成");
            }
        } 
        #endregion
    }
}

 

将excel保存完后,如何下载文件到本地?

参考.Net MVC 怎么上传文件和下载文件

 

 

 

 

 

 

 

 

 

 

相关文章
|
24天前
|
数据格式 UED
记录一次NPOI库导出Excel遇到的小问题解决方案
【11月更文挑战第16天】本文记录了使用 NPOI 库导出 Excel 过程中遇到的三个主要问题及其解决方案:单元格数据格式错误、日期格式不正确以及合并单元格边框缺失。通过自定义单元格样式、设置数据格式和手动添加边框,有效解决了这些问题,提升了导出文件的质量和用户体验。
148 3
|
2月前
|
Python
python读写操作excel日志
主要是读写操作,创建表格
65 2
|
2月前
|
索引 Python
Excel学习笔记(一):python读写excel,并完成计算平均成绩、成绩等级划分、每个同学分数大于70的次数、找最优成绩
这篇文章是关于如何使用Python读取Excel文件中的学生成绩数据,并进行计算平均成绩、成绩等级划分、统计分数大于70的次数以及找出最优成绩等操作的教程。
89 0
对excel读写的三个模块,xlsxwriter最牛,xlwt , xlrd,openpyxl
对excel读写的三个模块,xlsxwriter最牛,xlwt , xlrd,openpyxl
|
4月前
|
SQL JSON 关系型数据库
n种方式教你用python读写excel等数据文件
n种方式教你用python读写excel等数据文件
|
4月前
|
easyexcel Java 关系型数据库
阿里巴巴-EasyExcel 基于Java的简单、省内存的读写Excel
该文章主要介绍了在Java应用中如何使用EasyExcel技术完成对Excel文件的导入和导出操作,包括环境搭建、基本概念、快速入门、进阶操作和综合应用等内容,并提供了相关代码示例和注意事项。
 阿里巴巴-EasyExcel 基于Java的简单、省内存的读写Excel
|
5月前
|
Java 数据安全/隐私保护
Java无模版导出Excel 0基础教程
经常写数据导出到EXCEL,没有模板的情况下使用POI技术。以此作为记录,以后方便使用。 2 工具类 样式工具: 处理工具Java接口 水印工具 导出Excel工具类 3 测试代码 与实际复杂业务不同 在此我们只做模拟 Controller Service 4 导出测试 使用Postman进行接口测试,没接触过Postman的小伙伴可以看我这篇博客Postman导出excel文件保存为文件可以看到导出很成功,包括水印 sheet页名称自适应宽度。还有一些高亮……等功能可以直接搜索使用
111 0
Java无模版导出Excel 0基础教程
|
5月前
|
存储 对象存储 Python
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。
|
15天前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####
|
2月前
|
数据采集 存储 JavaScript
自动化数据处理:使用Selenium与Excel打造的数据爬取管道
本文介绍了一种使用Selenium和Excel结合代理IP技术从WIPO品牌数据库(branddb.wipo.int)自动化爬取专利信息的方法。通过Selenium模拟用户操作,处理JavaScript动态加载页面,利用代理IP避免IP封禁,确保数据爬取稳定性和隐私性。爬取的数据将存储在Excel中,便于后续分析。此外,文章还详细介绍了Selenium的基本设置、代理IP配置及使用技巧,并探讨了未来可能采用的更多防反爬策略,以提升爬虫效率和稳定性。
130 4