zoukankan      html  css  js  c++  java
  • C# --NPOI导出excel

    做项目过程中,导出项目碰到excel版本问题屡见不鲜,这个时候按照一般方法已经没办法解决了(个人水平有限),于是找度娘,发现有种NPOI导出excel的方法

    就是引用NPOI.DLL,可以不管版本问题了。

    完整代码如下,读取文件至datatable,再导出excel

    路径读取:

    private void button1_Click(object sender, EventArgs e)//选取文件
            {
                OpenFileDialog openFileDialog1 = new OpenFileDialog();
                if (openFileDialog1.ShowDialog() == DialogResult.OK)
                {
                    if (openFileDialog1.FileName != "")
                    {
                        this.textBox1.Text = openFileDialog1.FileName;
                    }
                }
            }

    主类:

     private void button6_Click(object sender, EventArgs e)
            {
                DataTable dataTable = new DataTable();
                dataTable = Csv2DT.csv2dt(this.textBox1.Text, 0, dataTable);//取文本框中的path
                String Text = dataTable.Rows[1]["物料编码"].ToString();//用于测试是不是读取成功
                NPOIoutputexcel.ExportToExcelData(dataTable, "sheet1");
            }

    转为datatable类如下

    class Csv2DT
        {
            /// <summary>
            /// 将Csv读入DataTable
            /// </summary>
            /// <param name="filePath">csv文件路径</param>
            /// <param name="n">表示第n行是字段title,第n+1行是记录开始</param>
            /// <param name="k">可选参数表示最后K行不算记录默认0</param>
            public static DataTable csv2dt(string filePath, int n, DataTable dt) //这个dt 是个空白的没有任何行列的DataTable
            {
                String csvSplitBy = "(?<=^|,)("(?:[^"]|"")*"|[^,]*)";
                StreamReader reader = new StreamReader(filePath, System.Text.Encoding.Default, false);
                int i = 0, m = 0;
                reader.Peek();
                while (reader.Peek() > 0)
                {
                    m = m + 1;
                    string str = reader.ReadLine();
                    if (m >= n + 1)
                    {
                        if (m == n + 1) //如果是字段行,则自动加入字段。
                        {
                            MatchCollection mcs = Regex.Matches(str, csvSplitBy);
                            foreach (Match mc in mcs)
                            {
                                dt.Columns.Add(mc.Value); //增加列标题
                            }
                        }
                        else
                        {
                            MatchCollection mcs = Regex.Matches(str, "(?<=^|,)("(?:[^"]|"")*"|[^,]*)");
                            i = 0;
                            System.Data.DataRow dr = dt.NewRow();
                            foreach (Match mc in mcs)
                            {
                                dr[i] = mc.Value;
                                i++;
                            }
                            dt.Rows.Add(dr);  //DataTable 增加一行     
                        }
                    }
                }
                return dt;
            }
         }

    NPOI导出excel,先要引用NPOI.DLL,可以网上下载

     static class NPOIoutputexcel
        {
            public static void ExportToExcelData(DataTable DataTable, string sheetName)
            {
                SaveFileDialog fileDialog = new SaveFileDialog();
                //fileDialog.Filter = "Excel(97-2003)|*.xls|Excel(2007-2013)|*.xlsx";
                fileDialog.Filter = "Excel|*.xls|Excel|*.xlsx";
                if (fileDialog.ShowDialog() == System.Windows.Forms.DialogResult.Cancel)
                {
                    return;
                }
                //IWorkbook workbook = new XSSFWorkbook();
                //1、基于NPOI创建工作簿及工作表对象
                HSSFWorkbook hssf = new HSSFWorkbook();//2007以下版本
                //XSSFWorkbook xssf = new XSSFWorkbook();//2007以上版本
                //根据不同的excel版本创建不同干的工作簿
                IWorkbook workbook = null;
    
                workbook = hssf;
    
                ISheet sheet = workbook.CreateSheet(sheetName);
                IRow rowHead = sheet.CreateRow(0);
    
                //填写表头
                for (int i = 0; i < DataTable.Columns.Count; i++)
                {
                    rowHead.CreateCell(i, CellType.String).SetCellValue(DataTable.Columns[i].ColumnName.ToString());
                }
                //填写内容
                for (int i = 0; i < DataTable.Rows.Count; i++)
                {
                    IRow row = sheet.CreateRow(i + 1);
                    for (int j = 0; j < DataTable.Columns.Count; j++)
                    {
                        row.CreateCell(j, CellType.String).SetCellValue(DataTable.Rows[i][j].ToString());
                    }
                }
    
                for (int i = 0; i < DataTable.Columns.Count; i++)
                {
                    sheet.AutoSizeColumn(i);
                }
    
                using (FileStream stream = File.OpenWrite(fileDialog.FileName))
                {
                    workbook.Write(stream);
                    stream.Close();
                }
                MessageBox.Show("导出数据成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
                GC.Collect();
            }
    
        }

  • 相关阅读:
    字符串转换的UnicodeDecodeError—— ‘\xa0’问题
    linux下nginx+uwsgi部署python应用
    字符串转换的UnicodeDecodeError—— ‘\xa0’问题
    python的get和post方式请求详解
    MindManager使用说明
    进入程序员的自由天地
    悦读上品 得乎益友
    C++ 是一门难学易用的语言!
    合上More Exceptional C++的瞬间
    从零开始学ASP.NET
  • 原文地址:https://www.cnblogs.com/BruceKing/p/13185924.html
Copyright © 2011-2022 走看看