NPOI_winfrom导出Excel表格(合并单元格规定范围加外边框存储路径弹框选择)
Posted Bonnie_W
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了NPOI_winfrom导出Excel表格(合并单元格规定范围加外边框存储路径弹框选择)相关的知识,希望对你有一定的参考价值。
1.导出
1 private void btn_print_Click(object sender, EventArgs e) 2 { 3 DataTable dtNew = new DataTable(); 4 5 dtNew.Columns.Add(new DataColumn("commodity_name", typeof(object))); 6 dtNew.Columns.Add(new DataColumn("specifications", typeof(object))); 7 dtNew.Columns.Add(new DataColumn("unit", typeof(object))); 8 dtNew.Columns.Add(new DataColumn("number", typeof(object))); 9 dtNew.Columns.Add(new DataColumn("price", typeof(object))); 10 dtNew.Columns.Add(new DataColumn("money", typeof(object))); 11 dtNew.Columns.Add(new DataColumn("settlement", typeof(object))); 12 13 for (int i = 0; i < dgv.Rows.Count; i++) 14 { 15 DataRow dr = dtNew.NewRow(); 16 dr["commodity_name"] = Convert.ToString(dgv.Rows[i].Cells[3].Value ?? ""); 17 dr["specifications"] = Convert.ToString(dgv.Rows[i].Cells[4].Value ?? ""); 18 dr["unit"] = Convert.ToString(dgv.Rows[i].Cells[5].Value ?? ""); 19 dr["number"] = Convert.ToString(dgv.Rows[i].Cells[8].Value ?? ""); 20 dr["price"] = Convert.ToString(dgv.Rows[i].Cells[6].Value ?? ""); 21 dr["money"] = Convert.ToString(dgv.Rows[i].Cells[7].Value ?? ""); 22 dr["settlement"] = Convert.ToString(dgv.Rows[i].Cells[9].Value ?? ""); 23 24 dtNew.Rows.Add(dr); 25 } 26 dgv2.DataSource = dtNew; 27 28 string xlsxName = "其他产品采购单_" + DateTime.Now.ToString("yyyyMMddHHmm") + ".xls"; //保存的Excel文件名 29 TableToExcelForXLSX(dtNew, xlsxName); //传入带出数据及文件名 30 }
1 private void TableToExcelForXLSX(System.Data.DataTable dt, string output) 2 { 3 FileStream file = new FileStream(output, FileMode.OpenOrCreate, FileAccess.ReadWrite); 4 try 5 { 6 HSSFWorkbook workbook = new HSSFWorkbook(); //XSSFWorkbook :用于表示高及低层次excel文件格式的类,实现workbook接口。 7 8 ISheet sheet = workbook.CreateSheet("sheet"); //ISheet:是一个工作表的高级表示,Row:行;Cell:单元格 9 IRow row = null;
//第一行 10 row = sheet.CreateRow(0);//在工作表中添加一行 11 ICell cell = row.CreateCell(0);//在行中添加一列 12 cell.SetCellValue("商品采购入库单");//设置列的内容 13 setCellStyle(workbook, cell); 14 mergeCell(sheet, 0, 0, 0, 6); //合并单元格 15 16 ICellStyle style = workbook.CreateCellStyle(); 17
//第二行 18 row = sheet.CreateRow(1); 19 row.CreateCell(0); 20 sheet.GetRow(1).GetCell(0).SetCellValue("供货单位:"); 21 22 row.CreateCell(1); 23 sheet.GetRow(1).GetCell(1).SetCellValue(txt_unitname.Text); 24 25 row.CreateCell(5); 26 sheet.GetRow(1).GetCell(5).SetCellValue((Convert.ToDateTime(dp_datetime.Text)).ToString("yyyy年MM月dd日")); 27
//第三行 28 29 row = sheet.CreateRow(2); //循环添加表头 30 for (int i = 0; i < dgv2.ColumnCount; i++) 31 { 32 row.CreateCell(i); 33 sheet.GetRow(2).GetCell(i).SetCellValue(dgv2.Columns[i].HeaderText); 34 //边框 35 style.BorderBottom = NPOI.SS.UserModel.BorderStyle.THIN; 36 style.BorderLeft = NPOI.SS.UserModel.BorderStyle.THIN; 37 style.BorderRight = NPOI.SS.UserModel.BorderStyle.THIN; 38 style.BorderTop = NPOI.SS.UserModel.BorderStyle.THIN; 39 style.BottomBorderColor = HSSFColor.BLACK.index; 40 style.LeftBorderColor = HSSFColor.BLACK.index; 41 style.RightBorderColor = HSSFColor.BLACK.index; 42 style.TopBorderColor = HSSFColor.BLACK.index; 43 row.GetCell(i).CellStyle = style; //规定单元格加边框 44 } 45 46 47 for (int i = 1; i <= dgv2.Rows.Count; i++) 48 { 49 row = sheet.CreateRow(i + 2); 50 for (int j = 0; j < dgv2.ColumnCount; j++) 51 { 52 row.CreateCell(j); 53 string str = dgv2.Rows[i - 1].Cells[j].Value.ToString(); 54 sheet.GetRow(i + 2).GetCell(j).SetCellValue(str); 55 style.BorderBottom = NPOI.SS.UserModel.BorderStyle.THIN; 56 style.BorderLeft = NPOI.SS.UserModel.BorderStyle.THIN; 57 style.BorderRight = NPOI.SS.UserModel.BorderStyle.THIN; 58 style.BorderTop = NPOI.SS.UserModel.BorderStyle.THIN; 59 style.BottomBorderColor = HSSFColor.BLACK.index; 60 style.LeftBorderColor = HSSFColor.BLACK.index; 61 style.RightBorderColor = HSSFColor.BLACK.index; 62 style.TopBorderColor = HSSFColor.BLACK.index; 63 row.GetCell(j).CellStyle = style; 64 } 65 } 66 row = sheet.CreateRow(dgv.Rows.Count + 7); 67 68 row.CreateCell(0); 69 sheet.GetRow(dgv.Rows.Count + 7).GetCell(0).SetCellValue("财务审核:"); 70 71 row.CreateCell(1); 72 sheet.GetRow(dgv.Rows.Count + 7).GetCell(1).SetCellValue(cb_auditing.Text); 73 74 row.CreateCell(3); 75 sheet.GetRow(dgv.Rows.Count + 7).GetCell(3).SetCellValue("实物负责人:"); 76 77 row.CreateCell(4); 78 sheet.GetRow(dgv.Rows.Count + 7).GetCell(4).SetCellValue(dgv.Rows[0].Cells[12].Value.ToString()); 79 80 row.CreateCell(5); 81 sheet.GetRow(dgv.Rows.Count + 7).GetCell(5).SetCellValue("制单人:"); 82 83 row.CreateCell(6); 84 sheet.GetRow(dgv.Rows.Count + 7).GetCell(6).SetCellValue(dgv.Rows[0].Cells[13].Value.ToString()); 85 86 // 存储路径弹框选择 87 SaveFileDialog saveDialog = new SaveFileDialog(); 88 saveDialog.DefaultExt = "xls"; 89 saveDialog.Filter = "Excel文件|*.xls"; 90 saveDialog.FileName = output; 91 saveDialog.ShowDialog(); 92 output = saveDialog.FileName; 93 if (output.IndexOf(":") < 0) return; //被点了取消 94 if (output != "") 95 { 96 try 97 { 98 file = File.OpenWrite(saveDialog.FileName); 99 workbook.Write(file); 100 //file.Close(); 101 //MessageBox.Show("导出成功!"); 102 } 103 catch (Exception ex) 104 { 105 MessageBox.Show("导出文件时出错,文件可能正被打开!\n" + ex.Message); 106 } 107 108 } 109 } 110 111 finally 112 { 113 if (file != null) 114 file.Close(); 115 GC.SuppressFinalize(this); 116 } 117 118 }
2.合并单元格、设置字体
1 private void mergeCell(ISheet sheet, int firstRow, int lastRow, int firstCell, int lastCell)
2 {
3 sheet.AddMergedRegion(new CellRangeAddress(firstRow, lastRow, firstCell, lastCell));//2.0使用 2.0以下为Region
4 }
5
6 private void setCellStyle(HSSFWorkbook workbook, ICell cell)
7 {
8 HSSFCellStyle fCellStyle = (HSSFCellStyle)workbook.CreateCellStyle();
9 HSSFFont ffont = (HSSFFont)workbook.CreateFont();
10 ffont.FontHeight = 20 * 20;
11 ffont.FontName = "宋体";
12 fCellStyle.SetFont(ffont);
13
14 fCellStyle.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.CENTER;//垂直对齐
15 fCellStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.CENTER;//水平对齐
16 cell.CellStyle = fCellStyle;
17 }
附加( 使用Microsoft.Office.Interop.Excel 导出Excel表格)
1 private void ExportExcels(string fileName, DataGridView myDGV) 2 { 3 string saveFileName = ""; 4 SaveFileDialog saveDialog = new SaveFileDialog(); 5 saveDialog.DefaultExt = "xls"; 6 saveDialog.Filter = "Excel文件|*.xls"; 7 saveDialog.FileName = fileName; 8 saveDialog.ShowDialog(); 9 saveFileName = saveDialog.FileName; 10 if (saveFileName.IndexOf(":") < 0) return;被点了取消 11 Microsoft.Office.Interop.Excel.Application xlApp = new Microsoft.Office.Interop.Excel.Application(); 12 if (xlApp == null) 13 { 14 MessageBox.Show("无法创建Excel对象,可能您的机子未安装Excel"); 15 return; 16 } 17 18 Microsoft.Office.Interop.Excel.Workbooks workbooks = xlApp.Workbooks; 19 Microsoft.Office.Interop.Excel.Workbook workbook = workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet); 20 Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[1];//取得sheet1 21 22 DataTable dtNew = new DataTable(); 23 24 dtNew.Columns.Add(new DataColumn("id", typeof(object))); 25 dtNew.Columns.Add(new DataColumn("datetime", typeof(object))); 26 dtNew.Columns.Add(new DataColumn("purchase_unit", typeof(object))); 27 dtNew.Columns.Add(new DataColumn("specifications", typeof(object))); 28 dtNew.Columns.Add(new DataColumn("unit", typeof(object))); 29 dtNew.Columns.Add(new DataColumn("number", typeof(object))); 30 dtNew.Columns.Add(new DataColumn("price", typeof(object))); 31 dtNew.Columns.Add(new DataColumn("money", typeof(object))); 32 dtNew.Columns.Add(new DataColumn("payment", typeof(object))); 33 dtNew.Columns.Add(new DataColumn("remain", typeof(object))); 34 35 for (int i = 0; i < dgv.Rows.Count; i++) 36 { 37 DataRow dr = dtNew.NewRow(); 38 39 dr["id"] = Convert.ToString(dgv.Rows[i].Cells[0].Value ?? ""); 40 dr["datetime"] = Convert.ToString(dgv.Rows[i].Cells[1].Value ?? ""); 41 dr["purchase_unit"] = Convert.ToString(dgv.Rows[i].Cells[2].Value ?? ""); 42 dr["specifications"] = Convert.ToString(dgv.Rows[i].Cells[4].Value ?? ""); 43 dr["unit"] = Convert.ToString(dgv.Rows[i].Cells[5].Value ?? ""); 44 dr["number"] = Convert.ToString(dgv.Rows[i].Cells[6].Value ?? ""); 45 dr["price"] = Convert.ToString(dgv.Rows[i].Cells[10].Value ?? ""); 46 dr["money"] = Convert.ToString(dgv.Rows[i].Cells[8].Value ?? ""); 47 dr["payment"] = Convert.ToString(dgv.Rows[i].Cells[9].Value ?? ""); 48 dr["remain"] = Convert.ToString(dgv.Rows[i].Cells[12].Value ?? ""); 49 50 dtNew.Rows.Add(dr); 51 } 52 dgv2.DataSource = dtNew; 53 Excel.Range titleRange = worksheet.Range[worksheet.Cells[1, 1], worksheet.Cells[1, 10]];//选取单元格 54 titleRange.Merge(true);//合并单元格 55 titleRange.Value2 = "其它商品销售明细汇总表";设置单元格内文本 56 titleRange.Font.Name = "宋体";//设置字体 57 titleRange.Font.Size = 28;//字体大小 58 titleRange.Font.Bold = false;//加粗显示 59 titleRange.HorizontalAlignment = Excel.XlHAlign.xlHAlignCenter;//水平居中 60 titleRange.VerticalAlignment = Excel.XlVAlign.xlVAlignCenter;//垂直居中 61 titleRange.Borders.LineStyle = Excel.XlLineStyle.xlContinuous;//设置边框 62 titleRange.Borders.Weight = Excel.XlBorderWeight.xlThin;//边框常规粗细 63 64 65 Excel.Range title_unitname = worksheet.Range[worksheet.Cells[2, 1], worksheet.Cells[2, 1]];//选取单元格 66 title_unitname.Merge(false);//合并单元格 67 title_unitname.Value2 = "商品名称:";设置单元格内文本 68 title_unitname.Font.Name = "宋体";//设置字体 69 title_unitname.Font.Size = 14;//字体大小 70 71 Excel.Range title_unitname2 = worksheet.Range[worksheet.Cells[2, 2], worksheet.Cells[2, 2]];//选取单元格 72 title_unitname2.Merge(false);//合并单元格 73 title_unitname2.Value2 = txt_commname.Text;设置单元格内文本 74 title_unitname2.Font.Name = "宋体";//设置字体 75 title_unitname2.Font.Size = 14;//字体大小 76 77 Excel.Range title_datetime = worksheet.Range[worksheet.Cells[2, 8], worksheet.Cells[2, 8]];//选取单元格 78 title_datetime.Merge(true);//合并单元格 79 title_datetime.Value2 = (Convert.ToDateTime(dp_datetime1.Text)).ToString("yyyy年MM月dd日");设置单元格内文本 80 title_datetime.Font.Name = "宋体";//设置字体 81 title_datetime.Font.Size = 14;//字体大小 82 83 Excel.Range title_z = worksheet.Range[worksheet.Cells[2, 9], worksheet.Cells[2,9]];//选取单元格 84 title_z.Merge(true);//合并单元格 85 title_z.Value2 = "至";设置单元格内文本 86 title_z.Font.Name = "宋体";//设置字体 87 title_z.Font.Size = 14;//字体大小 88 title_z.HorizontalAlignment = Excel.XlHAlign.xlHAlignCenter;//水平居中 89 90 Excel.Range title_datetime2 = worksheet.Range[worksheet.Cells[2, 10], worksheet.Cells[2,10]];//选取单元格 91 title_datetime2.Merge(true);//合并单元格 92 title_datetime2.Value2 = (Convert.ToDateTime(dp_datetime2.Text)).ToString("yyyy年MM月dd日");设置单元格内文本 93 title_datetime2.Font.Name = "宋体";//设置字体 94 title_datetime2.Font.Size = 14;//字体大小 95 96 for (int i = 0; i < dgv2.ColumnCount; i++) 97 { 98 worksheet.Cells[5, i + 2] = dgv.Columns[i].HeaderText; 99 Excel.Range title_dgv = worksheet.Range[worksheet.Cells[5, i + 1], worksheet.Cells[5, i + 1]]; 100 title_dgv.Merge(false);//合并单元格 101 title_dgv.Value2 = dgv2.Columns[i].HeaderText;设置单元格内文本 102 title_dgv.Font.Name = "宋体";//设置字体 103 title_dgv.Font.Size = 14;//字体大小 104 title_dgv.Borders.LineStyle = Excel.XlLineStyle.xlContinuous;//设置边框 105 title_dgv.Borders.Weight = Excel.XlBorderWeight.xlThin;//边框常规粗细 106 } 107 写入数值 108 for (int r = 0; r < dgv2.Rows.Count; r++) 109 { 110 for (int i = 0; i < dgv2.ColumnCount; i++) 111 { 112 Excel.Range title_dgvT = worksheet.Range[worksheet.Cells[r + 6, i + 1], worksheet.Cells[r + 6, i + 1]]; 113 worksheet.Cells[r + 6, i + 2] = dgv.Rows[r].Cells[i].Value; 114 title_dgvT.Merge(false);//合并单元格 115 title_dgvT.Value2 = dgv2.Rows[r].Cells[i].Value;设置单元格内文本 116 title_dgvT.Font.Name = "宋体";//设置字体 117 title_dgvT.Font.Size = 14;//字体大小 118 title_dgvT.Borders.LineStyle = Excel.XlLineStyle.xlContinuous;//设置边框 119 title_dgvT.Borders.Weight = Excel.XlBorderWeight.xlThin;//边框常规粗细 120 } 121 System.Windows.Forms.Application.DoEvents(); 122 } 123 124 125 Excel.Range title_auditing = worksheet.Range[worksheet.Cells[dgv.Rows.Count + 10, 1], worksheet.Cells[dgv.Rows.Count + 10, 1]];//选取单元格 126 title_auditing.Merge(false);//合并单元格 127 title_auditing.Value2 = "会计:";设置单元格内文本 128 title_auditing.Font.Name = "宋体";//设置字体 129 title_auditing.Font.Size = 14;//字体大小 130 131 Excel.Range title_auditing2 = worksheet.Range[worksheet.Cells[dgv.Rows.Count + 10, 2], worksheet.Cells[dgv.Rows.Count + 10, 2]];//选取单元格 132 title_auditing2.Merge(false);//合并单元格 133 title_auditing2.Value2 = dgv.Rows[0].Cells[10].Value;设置单元格内文本 134 title_auditing2.Font.Name = "宋体";//设置字体 135 title_auditing2.Font.Size = 14;//字体大小 136 137 worksheet.Cells[dgv.Rows.Count + 10, 1] = "财务审核:" + cb_auditing.Text; 138 139 140 141 Excel.Range title_docm = worksheet.Range[worksheet.Cells[dgv.Rows.Count + 10, 9], worksheet.Cells[dgv.Rows.Count + 10, 9]];//选取单元格 142 title_docm.Merge(false);//合并单元格 143 title_docm.Value2 = "制单人:";设置单元格内文本 144 title_docm.Font.Name = "宋体";//设置字体 145 title_docm.Font.Size = 14;//字体大小 146 147 148 Excel.Range title_docm2 = worksheet.Range[worksheet.Cells[dgv.Rows.Count + 10, 10], worksheet.Cells[dgv.Rows.Count + 10, 10]];//选取单元格 149 title_docm2.Merge(false);//合并单元格 150 title_docm2.Value2 = dgv.Rows[0].Cells[11].Value;设置单元格内文本 151 title_docm2.Font.Name = "宋体";//设置字体 152 title_docm2.Font.Size = 14;//字体大小 153 worksheet.Cells[dgv.Rows.Count + 10, 10] = "制单人:" + dgv.Rows[0].Cells[15].Value; 154 155 worksheet.Columns.EntireColumn.AutoFit();//列宽自适应 156 if (saveFileName != "") 157 { 158 try 159 { 160 workbook.Saved = true; 161 workbook.SaveCopyAs(saveFileName); 162 } 163 catch (Exception ex) 164 { 165 MessageBox.Show("导出文件时出错,文件可能正被打开!\n" + ex.Message); 166 } 167 } 168 xlApp.Quit(); 169 GC.Collect();//强行销毁 170 MessageBox.Show("文件: " + fileName + ".xls 保存成功", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Information); 171 }
以上是关于NPOI_winfrom导出Excel表格(合并单元格规定范围加外边框存储路径弹框选择)的主要内容,如果未能解决你的问题,请参考以下文章