码迷,mamicode.com
首页 > 其他好文 > 详细

NPOI导出Excel - 自动适应中文宽度(帮助类下载)

时间:2014-08-07 13:04:40      阅读:221      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   使用   os   io   文件   

前言

做了好几个Excel、Word导出,用了HTTP流导出伪Excel文件、用过Office组件(这东西在生产环境下相当麻烦,各种权限,**)。

最后决定使用NPOI组件来导出,好处很多很多了,这里不多说。

这篇文章呢,主要说一下Excel导出的细节以及问题。

我在制作这个Demo的时候使用的环境:

Visual Studio 2010、Office 2013 、Framework .NET 3.5 、NPOI 1.2.5(至于为什么没有选最新版 稍后说)

完成后的截图

bubuko.com,布布扣

从浏览器导出的Excel,打开并没有提示文件格式不对,这是真真的Excel格式。

从上图看出,列是自动适应了宽度了的,不会挤到一堆。

CreateSheet帮助类

        /// <summary>
        /// 创建工作簿
        /// </summary>
        /// <param name="fileName">下载文件名</param>
        /// <param name="dt">数据源</param>
        public static void CreateSheet(string fileName, DataTable dt)
        {
            HSSFWorkbook workbook = new HSSFWorkbook();
            MemoryStream ms = new MemoryStream();

            //创建一个名称为Payment的工作表
            ISheet paymentSheet = workbook.CreateSheet("Payment");

            //数据源
            DataTable tbPayment = dt;

            //头部标题
            IRow paymentHeaderRow = paymentSheet.CreateRow(0);

            //循环添加标题
            foreach (DataColumn column in tbPayment.Columns)
                paymentHeaderRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);

            // 内容
            int paymentRowIndex = 1;

            foreach (DataRow row in tbPayment.Rows)
            {
                IRow newRow = paymentSheet.CreateRow(paymentRowIndex);

                //循环添加列的对应内容
                foreach (DataColumn column in tbPayment.Columns)
                {
                    newRow.CreateCell(column.Ordinal).SetCellValue(row[column].ToString());
                }

                paymentRowIndex++;
            }

            //列宽自适应,只对英文和数字有效
            for (int i = 0; i <= dt.Rows.Count; i++)
            {
                paymentSheet.AutoSizeColumn(i);
            }
            //获取当前列的宽度,然后对比本列的长度,取最大值
            for (int columnNum = 0; columnNum <= dt.Rows.Count; columnNum++)
            {
                int columnWidth = paymentSheet.GetColumnWidth(columnNum) / 256;
                for (int rowNum = 1; rowNum <= paymentSheet.LastRowNum; rowNum++)
                {
                    IRow currentRow;
                    //当前行未被使用过
                    if (paymentSheet.GetRow(rowNum) == null)
                    {
                        currentRow = paymentSheet.CreateRow(rowNum);
                    }
                    else
                    {
                        currentRow = paymentSheet.GetRow(rowNum);
                    }

                    if (currentRow.GetCell(columnNum) != null)
                    {
                        ICell currentCell = currentRow.GetCell(columnNum);
                        int length = Encoding.Default.GetBytes(currentCell.ToString()).Length;
                        if (columnWidth < length)
                        {
                            columnWidth = length;
                        }
                    }
                }
                paymentSheet.SetColumnWidth(columnNum, columnWidth * 256);
            }

            //将表内容写入流 通知浏览器下载
            workbook.Write(ms);
            System.Web.HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xls", fileName));
            System.Web.HttpContext.Current.Response.BinaryWrite(ms.ToArray()); //进行二进制流下在

            workbook = null;
            ms.Close();
            ms.Dispose();
        }

        /// <summary>
        /// 虚拟 DataTable内容
        /// </summary>
        /// <returns></returns>
        public static DataTable CreatTable()
        {
            //创建DataTable 将数据库中没有的数据放到这个DT中
            DataTable datatable = new DataTable();
            datatable.Columns.Add("列1", typeof(string));
            datatable.Columns.Add("列2", typeof(string));
            datatable.Columns.Add("列3", typeof(string));
            //创建DatatTable 结束---------------------------

            //开始给临时datatable赋值
            for (int i = 0; i < 10; i++)
            {
                DataRow row = datatable.NewRow();
                row["列1"] = "列111111111111111111111111111111";
                row["列2"] = "列222222222222222222222222222222222222222";
                row["列3"] = "列3333333322222222222211111111111111111111111113";
                datatable.Rows.Add(row);
            }
            return datatable;
        }

代码中我加上了一个自己创建的DataTable作为数据源来进行导出,以免Demo用到数据库。

关于错误问题

当创建项目的版本高于NPOI基于的.net版本,会提示报错。

更换.net版本就行了。

另外官网提供的最新版是bate版本,我使用过程中会报错。还是选择2.0版本吧。

DEMO下载

360云盘 http://yunpan.cn/Qagu3ZYyYYqnW (提取码:0538)

相关资料

解决自适应宽不支持中文问题: http://blog.csdn.net/jerry_cool/article/details/7000085

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

NPOI大全:http://www.cnblogs.com/atao/category/209358.html

NPOI导出Excel - 自动适应中文宽度(帮助类下载),布布扣,bubuko.com

NPOI导出Excel - 自动适应中文宽度(帮助类下载)

标签:style   blog   http   color   使用   os   io   文件   

原文地址:http://www.cnblogs.com/likeli/p/3896667.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!