转载 NPOI.dll 用法。单元格,样式,字体,颜色,行高,宽度。读写excel

我用的版本是1.25的。每个版本用法有一点不同

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;
using NPOI.HSSF.UserModel;
using NPOI.HPSF;
using NPOI.POIFS.FileSystem;
using NPOI.HSSF.Util;
using NPOI.SS.UserModel;
using System.IO;
using SqlHelPerXHC;
using NPOI.HSSF.Record.CF;
namespace Excl
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        //http://tonyqus.sinaapp.com/page/4
        static ICellStyle Getcellstyle(IWorkbook wb, string str)
        {
            ICellStyle cellStyle = wb.CreateCellStyle();

            //字体
            IFont font12 = wb.CreateFont();
            font12.FontHeightInPoints = 10;

            font12.FontName = "微软雅黑";

            IFont font = wb.CreateFont();
            font.FontName = "微软雅黑";
            //font.Underline = 1;

            IFont fontcolorblue = wb.CreateFont();
            fontcolorblue.Color = HSSFColor.OLIVE_GREEN.BLUE.index;
            fontcolorblue.IsItalic = true;
            fontcolorblue.FontName = "微软雅黑";

            //边框
            cellStyle.BorderBottom = NPOI.SS.UserModel.BorderStyle.DOTTED;
            cellStyle.BorderLeft = NPOI.SS.UserModel.BorderStyle.HAIR;
            cellStyle.BorderRight = NPOI.SS.UserModel.BorderStyle.HAIR;
            cellStyle.BorderTop = NPOI.SS.UserModel.BorderStyle.DOTTED;
            //边框颜色
            cellStyle.BottomBorderColor = HSSFColor.OLIVE_GREEN.BLUE.index;
            cellStyle.TopBorderColor = HSSFColor.OLIVE_GREEN.BLUE.index;

            //背景
            //cellStyle.FillBackgroundColor = HSSFColor.OLIVE_GREEN.BLUE.index;
            //cellStyle.FillForegroundColor = HSSFColor.OLIVE_GREEN.BLUE.index;
            cellStyle.FillForegroundColor = HSSFColor.WHITE.index;
           // cellStyle.FillPattern = FillPatternType.NO_FILL;
            cellStyle.FillBackgroundColor = HSSFColor.MAROON.index;
            //水平对齐
            cellStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.LEFT;

            //垂直对齐
            cellStyle.VerticalAlignment = VerticalAlignment.CENTER;

            //自动换行
            cellStyle.WrapText = true;

            //缩进
            cellStyle.Indention = 0;
            switch (str)
            {
                case "头":
                   // cellStyle.FillPattern = FillPatternType.LEAST_DOTS;
                    cellStyle.SetFont(font12);
                    break;
                case "时间":
                    IDataFormat datastyle = wb.CreateDataFormat();

                    cellStyle.DataFormat = datastyle.GetFormat("yyyy/mm/dd");
                    cellStyle.SetFont(font);
                    break;
                case "数字":
                    cellStyle.DataFormat = HSSFDataFormat.GetBuiltinFormat("0.00");
                    cellStyle.SetFont(font);
                    break;
                case "钱":
                    IDataFormat format = wb.CreateDataFormat();
                    cellStyle.DataFormat = format.GetFormat("¥#,##0");
                    cellStyle.SetFont(font);
                    break;
                case "url":
                    fontcolorblue.Underline = 1;
                    cellStyle.SetFont(fontcolorblue);
                    break;
                case "百分比":
                    cellStyle.DataFormat = HSSFDataFormat.GetBuiltinFormat("0.00%");
                    cellStyle.SetFont(font);
                    break;
                case "中文大写":
                    IDataFormat format1 = wb.CreateDataFormat();
                    cellStyle.DataFormat = format1.GetFormat("[DbNum2][$-804]0");
                    cellStyle.SetFont(font);
                    break;
                case "科学计数法":
                    cellStyle.DataFormat = HSSFDataFormat.GetBuiltinFormat("0.00E+00");
                    cellStyle.SetFont(font);
                    break;
                case "默认":
                    cellStyle.SetFont(font);
                    break;
            }
            return cellStyle;

        }
        private void btnwrite_Click(object sender, EventArgs e)
        {
            //创建数据库
            IWorkbook wb = new HSSFWorkbook();

            //创建表
            ISheet sh = wb.CreateSheet("zhiyuan");
          //  sh.TabColorIndex = HSSFColor.RED.index;

            //设置单元的宽度
            sh.SetColumnWidth(0, 15 * 256);
            sh.SetColumnWidth(1, 35 * 256);
            sh.SetColumnWidth(2, 15 * 256);
            sh.SetColumnWidth(3, 10 * 256);

            //读取数据库写入表
            string sql = "select top 100 urlnam,url,bdtim,bdsl from zhiyuan";
            int i = 0;

            //合并单元格
            sh.AddMergedRegion(new NPOI.SS.Util.CellRangeAddress(0, 0, 0, 3));
            IRow row0 = sh.CreateRow(0);
            row0.Height = 20 * 20;
            ICell icell1top0 = row0.CreateCell(0);
            ICell icell1top1 = row0.CreateCell(1);
            ICell icell1top2 = row0.CreateCell(2);
            ICell icell1top3 = row0.CreateCell(3);
            icell1top0.CellStyle = Getcellstyle(wb, "头");
            icell1top0.SetCellValue("标题合并单元");

            IRow row1 = sh.CreateRow(1);
            row1.Height = 20 * 20;

            ICell icell1top = row1.CreateCell(0);
            icell1top.CellStyle = Getcellstyle(wb, "头");
            icell1top.SetCellValue("网站名");

            ICell icell2top = row1.CreateCell(1);
            icell2top.CellStyle = Getcellstyle(wb, "头");
            icell2top.SetCellValue("网址");

            ICell icell3top = row1.CreateCell(2);
            icell3top.CellStyle = Getcellstyle(wb, "头");
            icell3top.SetCellValue("百度快照");

            ICell icell4top = row1.CreateCell(3);
            icell4top.CellStyle = Getcellstyle(wb, "头");
            icell4top.SetCellValue("百度收录");

            i++;
            i++;

            using (SqlDataReader dr = SqlHelper.ExecuteReaderText(sql, null))
            {
                if (dr.HasRows)
                {
                    while (dr.Read())
                    {
                        IRow row = sh.CreateRow(i);
                        row.Height = 18 * 20;

                        ICell icell = row.CreateCell(0);
                        icell.CellStyle = Getcellstyle(wb, "默认");
                        icell.SetCellValue(dr.GetValue(0).ToString());

                        ICell icell1 = row.CreateCell(1);
                        icell1.CellStyle = Getcellstyle(wb, "url");
                        icell1.SetCellValue(dr.GetValue(1).ToString());
                        HSSFHyperlink link = new HSSFHyperlink(HyperlinkType.URL);
                        link.Address = (dr.GetValue(1).ToString());
                        icell1.Hyperlink = (link);

                        ICell icell2 = row.CreateCell(2);
                        icell2.CellStyle = Getcellstyle(wb, "时间");
                        icell2.SetCellValue(dr.IsDBNull(2) ? Convert.ToDateTime("1990-1-1") : dr.GetDateTime(2));

                        ICell icell3 = row.CreateCell(3);
                        icell3.CellStyle = Getcellstyle(wb, "默认");
                        icell3.SetCellValue(dr.IsDBNull(3) ? 0 : dr.GetInt32(3));
                        i++;
                    }
                }
            }
            using (FileStream fs = File.OpenWrite("xxx.xls"))
            {
                wb.Write(fs);
                MessageBox.Show("Excel已经写入成功!");
            }

        }

        private void CreateRow(IRow row, int j, SqlDataReader dr, ICellStyle cellstyle)
        {
            if (dr.GetFieldType(j).Name == "Int32")
            {

                row.CreateCell(j).SetCellValue(dr.IsDBNull(j) ? 0 : dr.GetInt32(j));
            }
            else if (dr.GetFieldType(j).Name == "Int16")
            { row.CreateCell(j).SetCellValue(dr.IsDBNull(j) ? 0 : dr.GetInt16(j)); }
            else if (dr.GetFieldType(j).Name == "Int64")
            { row.CreateCell(j).SetCellValue(dr.IsDBNull(j) ? 0 : dr.GetInt64(j)); }
            else if (dr.GetFieldType(j).Name == "String")
            { row.CreateCell(j).SetCellValue(dr.IsDBNull(j) ? "" : dr.GetString(j)); }
            else if (dr.GetFieldType(j).Name == "DateTime")
            {

                ICell cell = row.CreateCell(j);
                cell.CellStyle = cellstyle;
                cell.SetCellValue(dr.IsDBNull(j) ? Convert.ToDateTime("1990-1-1") : dr.GetDateTime(j));

            }
            else if (dr.GetFieldType(j).Name == "Double")
            { row.CreateCell(j).SetCellValue(dr.IsDBNull(j) ? 0 : dr.GetDouble(j)); }
            else if (dr.GetFieldType(j).Name == "Byte[]")
            { row.CreateCell(j).SetCellValue(dr.IsDBNull(j) ? 0 : dr.GetByte(j)); }
            else if (dr.GetFieldType(j).Name == "Decimal")
            { row.CreateCell(j).SetCellValue(dr.IsDBNull(j) ? 0 : dr.GetDouble(j)); }
            else
            {

                row.CreateCell(j).SetCellValue(dr.IsDBNull(j) ? "" : dr.GetValue(j).ToString());
            }

        }

        private void btnreade_Click(object sender, EventArgs e)
        {
            //先创建文件流
            if (DialogResult.OK == openFileDialog1.ShowDialog())
            {
                using (FileStream fs = File.OpenRead(openFileDialog1.FileName))
                {
                    //申明数据库对像
                    IWorkbook wk = new HSSFWorkbook(fs);

                    //获取数据库中的每个表
                    for (int i = 0; i < wk.NumberOfSheets; i++)
                    {
                        //申明表
                        ISheet wk1 = wk.GetSheetAt(i);

                        txtout.AppendText("====================" + wk1.SheetName + "================\r\n");

                        //获取表的行
                        for (int j = 0; j < wk1.LastRowNum + 1; j++)
                        {
                            //申明行
                            IRow row = wk1.GetRow(j);
                            for (int k = 0; k < row.LastCellNum + 1; k++)
                            {
                                txtout.AppendText(string.Format("{0}\t", row.GetCell(k) == null ? "" : row.GetCell(k).ToString()));
                            }
                            txtout.AppendText("\r\n");
                        }
                    }

                }
            }

        }

        //把excel 转成htm

        private void button1_Click(object sender, EventArgs e)
        {
            if (DialogResult.OK == openFileDialog1.ShowDialog())
            {
                string str = htmlxsl.Gethtmlxls(openFileDialog1.FileName);
                using (FileStream fs = File.OpenWrite("1.htm"))
                {
                    byte[] b = Encoding.Default.GetBytes(str);
                    fs.Write(b,0,b.Length);
                }
            }
        }
    }

}

生成htm的类 

using System.Text;
using NPOI.HSSF.UserModel;
using NPOI.HPSF;
using NPOI.POIFS.FileSystem;
using NPOI.HSSF.Util;
using NPOI.SS.UserModel;
using System.IO;
using SqlHelPerXHC;
using NPOI.HSSF.Record.CF;
namespace Excl
{
    public static class htmlxsl
    {
        private static ISheet sht;
        public static string Gethtmlxls(string path)
        {

            IWorkbook wb = new HSSFWorkbook(new FileStream(path, FileMode.Open));
            sht = wb.GetSheet("zhiyuan");
            //取行Excel的最大行数
            int rowsCount = sht.LastRowNum;
            //为保证Table布局与Excel一样,这里应该取所有行中的最大列数(需要遍历整个Sheet)。
            //为少一交全Excel遍历,提高性能,我们可以人为把第0行的列数调整至所有行中的最大列数。
            int colsCount = sht.GetRow(0).LastCellNum;
            int colSpan;
            int rowSpan;
            bool isByRowMerged;
            StringBuilder table = new StringBuilder(rowsCount * 32);
            table.Append("<table border=‘1px‘>");
            for (int rowIndex = 0; rowIndex < rowsCount; rowIndex++)
            {
                table.Append("<tr>");
                for (int colIndex = 0; colIndex < colsCount; colIndex++)
                {
                    GetTdMergedInfo(rowIndex, colIndex, out colSpan, out rowSpan, out isByRowMerged);
                    //如果已经被行合并包含进去了就不输出TD了。
                    //注意被合并的行或列不输出的处理方式不一样,见下面一处的注释说明了列合并后不输出TD的处理方式。
                    if (isByRowMerged)
                    {
                        continue;
                    }
                    table.Append("<td");
                    if (colSpan > 1)
                        table.Append(string.Format(" colSpan={0}", colSpan));
                    if (rowSpan > 1)
                        table.Append(string.Format(" rowSpan={0}", rowSpan));
                    table.Append(">");
                    table.Append(sht.GetRow(rowIndex).GetCell(colIndex));
                    //列被合并之后此行将少输出colSpan-1个TD。
                    if (colSpan > 1)
                        colIndex += colSpan - 1;
                    table.Append("</td>");
                }
                table.Append("</tr>");
            }
            table.Append("</table>");
            return table.ToString();

        }
        /// <summary>
        ///  获取Table某个TD合并的列数和行数等信息。与Excel中对应Cell的合并行数和列数一致。
        /// </summary>
        /// <param name="rowIndex">行号</param>
        /// <param name="colIndex">列号</param>
        ///  <param name="colspan">TD中需要合并的行数</param>
        /// <param name="rowspan">TD中需要合并的列数</param>
        /// <param name="rowspan">此单元格是否被某个行合并包含在内。如果被包含在内,将不输出TD。</param>
        /// <returns></returns>
        private static void GetTdMergedInfo(int rowIndex, int colIndex, out int colspan, out int rowspan, out bool isByRowMerged)
        {
            colspan = 1;
            rowspan = 1;
            isByRowMerged = false;
            int regionsCuont = sht.NumMergedRegions;

            NPOI.SS.Util.CellRangeAddress region;

            for (int i = 0; i < regionsCuont; i++)
            {

                region = sht.GetMergedRegion(i);

                if (region.FirstRow == rowIndex && region.FirstColumn == colIndex)
                {
                    colspan = region.LastColumn - region.FirstColumn + 1;
                    rowspan = region.LastRow - region.FirstRow + 1;
                    return;
                }
                else if (rowIndex > region.FirstRow && rowIndex <= region.LastRow && colIndex >= region.FirstColumn && colIndex <= region.LastColumn)
                {
                    isByRowMerged = true;
                }
            }
        }
    }
}
时间: 2024-10-11 07:07:00

转载 NPOI.dll 用法。单元格,样式,字体,颜色,行高,宽度。读写excel的相关文章

如何快速选中某单元格所在的整行或整列 Excel教程

我们可以使用快捷键的操作来快速选中B3单元格所在的整行或整列,操作方法如下,请大家参阅! 一.正规的快捷键操作 ①快速选中整行 按下键盘上的 Shift Space 即同时按下键盘上的Shift 空格键,这样,就能快速选中B3所在行的整行了. 操作方法注意,可先按下Shift不放,再按下空格键,这样更容易选中整行. ②快速选中整列 按下键盘上的 Ctrl Space 即同时按下键盘上的Ctrl 空格键,这样,就能快速选中B3所在行的整列了. 操作方法注意,可选按下Ctrl不放,再按下空格键,这样

NPOI.dll 用法。单元格,样式,字体,颜色,行高,宽度。读写excel

1.25 NPOI.dll using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using System.Data.SqlClient; using NPOI.HSSF.UserMod

NPOI.dll 用法:单元格、样式、字体、颜色、行高、宽度 读写excel

1.25 NPOI.dll using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using System.Data.SqlClient; using NPOI.HSSF.UserMod

用NPOI创建Excel、合并单元格、设置单元格样式、边框的方法

今天在做项目中,遇到使用代码生成具有一定样式的Excel,找了很多资料,最后终于解决了,Excel中格式的设置,以及单元格的合并等等.下面就介绍下,使用NPOI类库操作Excel的方法. 1.首先我们先在内存中生成一个Excel文件,代码如下:   HSSFWorkbook book = new HSSFWorkbook();        ISheet sheet = book.CreateSheet("Sheet1"); 2.然后在新创建的sheet里面,创建我们的行和列,代码如下

NPOI 生成Excel (单元格合并、设置单元格样式:字段,颜色、设置单元格为下拉框并限制输入值、设置单元格只能输入数字等)

NPIO源码地址:https://github.com/tonyqus/npoi NPIO使用参考:源码中的 NPOITest项目 下面代码包括: 1.包含多个Sheet的Excel 2.单元格合并 3.设置单元格样式:字段,颜色 4.设置单元格为下拉框并限制输入值 5.设置单元格只能输入数字 // // GET: /Excel/ public ActionResult Write() { var workbook = new HSSFWorkbook();//从流内容创建Workbook对象

excel套用单元格样式进行美化

与表格样式的内容相似,单元格样式中也包含字体.边框.填充和数字格式等效果,直接使用能实现快速美化单元格的目的.(常见问题)Excel表格样式的套用与创建如何把内容粘贴到excel单元格时自动套用excel的单元格格式excel怎样取消套用表格格式excel如何自定义套用表格格式怎么新增并设置 [解决方法,教程视频资料如下]资料来源:http://edu.51cto.com/course/15224.html 完整资料:http://edu.51cto.com/lecturer/13162026.

EasyExcel使用及自定义设置单元格样式

固定模板方式,首先创建要Excel数据列模板:当然EasyExcel 中也可以动态自定义表头,其实都差不多一样 下面案例中,我采用一个固定模板方式,主要记录下,如何自定义单元格样式 这里是导出方法,主要是绑定样式,指定Excel文件生成的路径 public static String ExcelWrite(ExportParamDto excelData) { String fileName = getPath() + System.currentTimeMillis() + ".xlsx&qu

UITableViewCell 单元格样式

UITableViewCell 单元格样式作用 1 typedef NS_ENUM(NSInteger, UITableViewCellStyle) { 2 UITableViewCellStyleDefault, // Simple cell with text label and optional image view (behavior of UITableViewCell in iPhoneOS 2.x) 3 UITableViewCellStyleValue1, // Left ali

127使用 TableView 自带的单元格样式实现好友列表,另外在单元格中添加辅助按钮

类似的做法如之前这篇随笔:114自定义 UITableViewCell 实现好友列表(扩展知识:如何使用xib创建自定义的表格视图单元格 KMTableViewCell) 相比之下:自定义 UITableViewCell 的内容灵活,可根据需求调整展示效果,应用场景更广:一般适用于TableView 自带的单元格样式无法实现的效果. 效果如下: ViewController.h 1 #import <UIKit/UIKit.h> 2 3 @interface ViewController :