NPOI_winfrom导出Excel表格(一)(合并单元格、规定范围加外边框、存储路径弹框选择)
1.导出
private void btn_print_Click(object sender, EventArgs e)
{
DataTable dtNew = new DataTable(); dtNew.Columns.Add(new DataColumn("commodity_name", typeof(object)));
dtNew.Columns.Add(new DataColumn("specifications", typeof(object)));
dtNew.Columns.Add(new DataColumn("unit", typeof(object)));
dtNew.Columns.Add(new DataColumn("number", typeof(object)));
dtNew.Columns.Add(new DataColumn("price", typeof(object)));
dtNew.Columns.Add(new DataColumn("money", typeof(object)));
dtNew.Columns.Add(new DataColumn("settlement", typeof(object))); for (int i = ; i < dgv.Rows.Count; i++)
{
DataRow dr = dtNew.NewRow();
dr["commodity_name"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["specifications"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["unit"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["number"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["price"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["money"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["settlement"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? ""); dtNew.Rows.Add(dr);
}
dgv2.DataSource = dtNew; string xlsxName = "其他产品采购单_" + DateTime.Now.ToString("yyyyMMddHHmm") + ".xls"; //保存的Excel文件名
TableToExcelForXLSX(dtNew, xlsxName); //传入带出数据及文件名
}
private void TableToExcelForXLSX(System.Data.DataTable dt, string output)
{
FileStream file = new FileStream(output, FileMode.OpenOrCreate, FileAccess.ReadWrite);
try
{
HSSFWorkbook workbook = new HSSFWorkbook(); //XSSFWorkbook :用于表示高及低层次excel文件格式的类,实现workbook接口。 ISheet sheet = workbook.CreateSheet("sheet"); //ISheet:是一个工作表的高级表示,Row:行;Cell:单元格
IRow row = null;
//第一行
row = sheet.CreateRow();//在工作表中添加一行
ICell cell = row.CreateCell();//在行中添加一列
cell.SetCellValue("商品采购入库单");//设置列的内容
setCellStyle(workbook, cell);
mergeCell(sheet, , , , ); //合并单元格 ICellStyle style = workbook.CreateCellStyle();
//第二行
row = sheet.CreateRow();
row.CreateCell();
sheet.GetRow().GetCell().SetCellValue("供货单位:"); row.CreateCell();
sheet.GetRow().GetCell().SetCellValue(txt_unitname.Text); row.CreateCell();
sheet.GetRow().GetCell().SetCellValue((Convert.ToDateTime(dp_datetime.Text)).ToString("yyyy年MM月dd日"));
//第三行 row = sheet.CreateRow(); //循环添加表头
for (int i = ; i < dgv2.ColumnCount; i++)
{
row.CreateCell(i);
sheet.GetRow().GetCell(i).SetCellValue(dgv2.Columns[i].HeaderText);
//边框
style.BorderBottom = NPOI.SS.UserModel.BorderStyle.THIN;
style.BorderLeft = NPOI.SS.UserModel.BorderStyle.THIN;
style.BorderRight = NPOI.SS.UserModel.BorderStyle.THIN;
style.BorderTop = NPOI.SS.UserModel.BorderStyle.THIN;
style.BottomBorderColor = HSSFColor.BLACK.index;
style.LeftBorderColor = HSSFColor.BLACK.index;
style.RightBorderColor = HSSFColor.BLACK.index;
style.TopBorderColor = HSSFColor.BLACK.index;
row.GetCell(i).CellStyle = style; //规定单元格加边框
} for (int i = ; i <= dgv2.Rows.Count; i++)
{
row = sheet.CreateRow(i + );
for (int j = ; j < dgv2.ColumnCount; j++)
{
row.CreateCell(j);
string str = dgv2.Rows[i - ].Cells[j].Value.ToString();
sheet.GetRow(i + ).GetCell(j).SetCellValue(str);
style.BorderBottom = NPOI.SS.UserModel.BorderStyle.THIN;
style.BorderLeft = NPOI.SS.UserModel.BorderStyle.THIN;
style.BorderRight = NPOI.SS.UserModel.BorderStyle.THIN;
style.BorderTop = NPOI.SS.UserModel.BorderStyle.THIN;
style.BottomBorderColor = HSSFColor.BLACK.index;
style.LeftBorderColor = HSSFColor.BLACK.index;
style.RightBorderColor = HSSFColor.BLACK.index;
style.TopBorderColor = HSSFColor.BLACK.index;
row.GetCell(j).CellStyle = style;
}
}
row = sheet.CreateRow(dgv.Rows.Count + ); row.CreateCell();
sheet.GetRow(dgv.Rows.Count + ).GetCell().SetCellValue("财务审核:"); row.CreateCell();
sheet.GetRow(dgv.Rows.Count + ).GetCell().SetCellValue(cb_auditing.Text); row.CreateCell();
sheet.GetRow(dgv.Rows.Count + ).GetCell().SetCellValue("实物负责人:"); row.CreateCell();
sheet.GetRow(dgv.Rows.Count + ).GetCell().SetCellValue(dgv.Rows[].Cells[].Value.ToString()); row.CreateCell();
sheet.GetRow(dgv.Rows.Count + ).GetCell().SetCellValue("制单人:"); row.CreateCell();
sheet.GetRow(dgv.Rows.Count + ).GetCell().SetCellValue(dgv.Rows[].Cells[].Value.ToString()); // 存储路径弹框选择
SaveFileDialog saveDialog = new SaveFileDialog();
saveDialog.DefaultExt = "xls";
saveDialog.Filter = "Excel文件|*.xls";
saveDialog.FileName = output;
saveDialog.ShowDialog();
output = saveDialog.FileName;
if (output.IndexOf(":") < ) return; //被点了取消
if (output != "")
{
try
{
file = File.OpenWrite(saveDialog.FileName);
workbook.Write(file);
//file.Close();
//MessageBox.Show("导出成功!");
}
catch (Exception ex)
{
MessageBox.Show("导出文件时出错,文件可能正被打开!\n" + ex.Message);
} }
} finally
{
if (file != null)
file.Close();
GC.SuppressFinalize(this);
} }
2.合并单元格、设置字体
private void mergeCell(ISheet sheet, int firstRow, int lastRow, int firstCell, int lastCell)
{
sheet.AddMergedRegion(new CellRangeAddress(firstRow, lastRow, firstCell, lastCell));//2.0使用 2.0以下为Region
} private void setCellStyle(HSSFWorkbook workbook, ICell cell)
{
HSSFCellStyle fCellStyle = (HSSFCellStyle)workbook.CreateCellStyle();
HSSFFont ffont = (HSSFFont)workbook.CreateFont();
ffont.FontHeight = * ;
ffont.FontName = "宋体";
fCellStyle.SetFont(ffont); fCellStyle.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.CENTER;//垂直对齐
fCellStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.CENTER;//水平对齐
cell.CellStyle = fCellStyle;
}
附加( 使用Microsoft.Office.Interop.Excel 导出Excel表格)
private void ExportExcels(string fileName, DataGridView myDGV)
{
string saveFileName = "";
SaveFileDialog saveDialog = new SaveFileDialog();
saveDialog.DefaultExt = "xls";
saveDialog.Filter = "Excel文件|*.xls";
saveDialog.FileName = fileName;
saveDialog.ShowDialog();
saveFileName = saveDialog.FileName;
if (saveFileName.IndexOf(":") < ) return;被点了取消
Microsoft.Office.Interop.Excel.Application xlApp = new Microsoft.Office.Interop.Excel.Application();
if (xlApp == null)
{
MessageBox.Show("无法创建Excel对象,可能您的机子未安装Excel");
return;
} Microsoft.Office.Interop.Excel.Workbooks workbooks = xlApp.Workbooks;
Microsoft.Office.Interop.Excel.Workbook workbook = workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);
Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[];//取得sheet1 DataTable dtNew = new DataTable(); dtNew.Columns.Add(new DataColumn("id", typeof(object)));
dtNew.Columns.Add(new DataColumn("datetime", typeof(object)));
dtNew.Columns.Add(new DataColumn("purchase_unit", typeof(object)));
dtNew.Columns.Add(new DataColumn("specifications", typeof(object)));
dtNew.Columns.Add(new DataColumn("unit", typeof(object)));
dtNew.Columns.Add(new DataColumn("number", typeof(object)));
dtNew.Columns.Add(new DataColumn("price", typeof(object)));
dtNew.Columns.Add(new DataColumn("money", typeof(object)));
dtNew.Columns.Add(new DataColumn("payment", typeof(object)));
dtNew.Columns.Add(new DataColumn("remain", typeof(object))); for (int i = ; i < dgv.Rows.Count; i++)
{
DataRow dr = dtNew.NewRow(); dr["id"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["datetime"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["purchase_unit"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["specifications"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["unit"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["number"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["price"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["money"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["payment"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? "");
dr["remain"] = Convert.ToString(dgv.Rows[i].Cells[].Value ?? ""); dtNew.Rows.Add(dr);
}
dgv2.DataSource = dtNew;
Excel.Range titleRange = worksheet.Range[worksheet.Cells[, ], worksheet.Cells[, ]];//选取单元格
titleRange.Merge(true);//合并单元格
titleRange.Value2 = "其它商品销售明细汇总表";设置单元格内文本
titleRange.Font.Name = "宋体";//设置字体
titleRange.Font.Size = ;//字体大小
titleRange.Font.Bold = false;//加粗显示
titleRange.HorizontalAlignment = Excel.XlHAlign.xlHAlignCenter;//水平居中
titleRange.VerticalAlignment = Excel.XlVAlign.xlVAlignCenter;//垂直居中
titleRange.Borders.LineStyle = Excel.XlLineStyle.xlContinuous;//设置边框
titleRange.Borders.Weight = Excel.XlBorderWeight.xlThin;//边框常规粗细 Excel.Range title_unitname = worksheet.Range[worksheet.Cells[, ], worksheet.Cells[, ]];//选取单元格
title_unitname.Merge(false);//合并单元格
title_unitname.Value2 = "商品名称:";设置单元格内文本
title_unitname.Font.Name = "宋体";//设置字体
title_unitname.Font.Size = ;//字体大小 Excel.Range title_unitname2 = worksheet.Range[worksheet.Cells[, ], worksheet.Cells[, ]];//选取单元格
title_unitname2.Merge(false);//合并单元格
title_unitname2.Value2 = txt_commname.Text;设置单元格内文本
title_unitname2.Font.Name = "宋体";//设置字体
title_unitname2.Font.Size = ;//字体大小 Excel.Range title_datetime = worksheet.Range[worksheet.Cells[, ], worksheet.Cells[, ]];//选取单元格
title_datetime.Merge(true);//合并单元格
title_datetime.Value2 = (Convert.ToDateTime(dp_datetime1.Text)).ToString("yyyy年MM月dd日");设置单元格内文本
title_datetime.Font.Name = "宋体";//设置字体
title_datetime.Font.Size = ;//字体大小 Excel.Range title_z = worksheet.Range[worksheet.Cells[, ], worksheet.Cells[,]];//选取单元格
title_z.Merge(true);//合并单元格
title_z.Value2 = "至";设置单元格内文本
title_z.Font.Name = "宋体";//设置字体
title_z.Font.Size = ;//字体大小
title_z.HorizontalAlignment = Excel.XlHAlign.xlHAlignCenter;//水平居中 Excel.Range title_datetime2 = worksheet.Range[worksheet.Cells[, ], worksheet.Cells[,]];//选取单元格
title_datetime2.Merge(true);//合并单元格
title_datetime2.Value2 = (Convert.ToDateTime(dp_datetime2.Text)).ToString("yyyy年MM月dd日");设置单元格内文本
title_datetime2.Font.Name = "宋体";//设置字体
title_datetime2.Font.Size = ;//字体大小 for (int i = ; i < dgv2.ColumnCount; i++)
{
worksheet.Cells[, i + ] = dgv.Columns[i].HeaderText;
Excel.Range title_dgv = worksheet.Range[worksheet.Cells[, i + ], worksheet.Cells[, i + ]];
title_dgv.Merge(false);//合并单元格
title_dgv.Value2 = dgv2.Columns[i].HeaderText;设置单元格内文本
title_dgv.Font.Name = "宋体";//设置字体
title_dgv.Font.Size = ;//字体大小
title_dgv.Borders.LineStyle = Excel.XlLineStyle.xlContinuous;//设置边框
title_dgv.Borders.Weight = Excel.XlBorderWeight.xlThin;//边框常规粗细
}
写入数值
for (int r = ; r < dgv2.Rows.Count; r++)
{
for (int i = ; i < dgv2.ColumnCount; i++)
{
Excel.Range title_dgvT = worksheet.Range[worksheet.Cells[r + , i + ], worksheet.Cells[r + , i + ]];
worksheet.Cells[r + , i + ] = dgv.Rows[r].Cells[i].Value;
title_dgvT.Merge(false);//合并单元格
title_dgvT.Value2 = dgv2.Rows[r].Cells[i].Value;设置单元格内文本
title_dgvT.Font.Name = "宋体";//设置字体
title_dgvT.Font.Size = ;//字体大小
title_dgvT.Borders.LineStyle = Excel.XlLineStyle.xlContinuous;//设置边框
title_dgvT.Borders.Weight = Excel.XlBorderWeight.xlThin;//边框常规粗细
}
System.Windows.Forms.Application.DoEvents();
} Excel.Range title_auditing = worksheet.Range[worksheet.Cells[dgv.Rows.Count + , ], worksheet.Cells[dgv.Rows.Count + , ]];//选取单元格
title_auditing.Merge(false);//合并单元格
title_auditing.Value2 = "会计:";设置单元格内文本
title_auditing.Font.Name = "宋体";//设置字体
title_auditing.Font.Size = ;//字体大小 Excel.Range title_auditing2 = worksheet.Range[worksheet.Cells[dgv.Rows.Count + , ], worksheet.Cells[dgv.Rows.Count + , ]];//选取单元格
title_auditing2.Merge(false);//合并单元格
title_auditing2.Value2 = dgv.Rows[].Cells[].Value;设置单元格内文本
title_auditing2.Font.Name = "宋体";//设置字体
title_auditing2.Font.Size = ;//字体大小 worksheet.Cells[dgv.Rows.Count + , ] = "财务审核:" + cb_auditing.Text; Excel.Range title_docm = worksheet.Range[worksheet.Cells[dgv.Rows.Count + , ], worksheet.Cells[dgv.Rows.Count + , ]];//选取单元格
title_docm.Merge(false);//合并单元格
title_docm.Value2 = "制单人:";设置单元格内文本
title_docm.Font.Name = "宋体";//设置字体
title_docm.Font.Size = ;//字体大小 Excel.Range title_docm2 = worksheet.Range[worksheet.Cells[dgv.Rows.Count + , ], worksheet.Cells[dgv.Rows.Count + , ]];//选取单元格
title_docm2.Merge(false);//合并单元格
title_docm2.Value2 = dgv.Rows[].Cells[].Value;设置单元格内文本
title_docm2.Font.Name = "宋体";//设置字体
title_docm2.Font.Size = ;//字体大小
worksheet.Cells[dgv.Rows.Count + , ] = "制单人:" + dgv.Rows[].Cells[].Value; worksheet.Columns.EntireColumn.AutoFit();//列宽自适应
if (saveFileName != "")
{
try
{
workbook.Saved = true;
workbook.SaveCopyAs(saveFileName);
}
catch (Exception ex)
{
MessageBox.Show("导出文件时出错,文件可能正被打开!\n" + ex.Message);
}
}
xlApp.Quit();
GC.Collect();//强行销毁
MessageBox.Show("文件: " + fileName + ".xls 保存成功", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
NPOI_winfrom导出Excel表格(一)(合并单元格、规定范围加外边框、存储路径弹框选择)的更多相关文章
- C# 如何使用NPOI操作Excel以及读取合并单元格等
C#操作Excel方法有很多,以前用的需要电脑安装office才能用,但因为版权问题公司不允许安装office.所以改用NPOI进行Excel操作,基本上一些简单的Excel操作都没有问题,读写合并单 ...
- NPOI_winfrom导出Excel表格(二)(直接打开Excel软件,将数据填充在当前的sheet中)
//// 存储路径弹框选择 SaveFileDialog saveDialog = new SaveFileDialog(); saveDialog.DefaultExt = "xls&qu ...
- C# 获取Excel中的合并单元格
C# 获取Excel中的合并单元格 我们在制作表格时,有时经常需要合并及取消合并一些单元格.在取消合并单元格时需要逐个查找及取消,比较麻烦.这里分享一个简单的方法来识别Excel中的合并单元格,识别这 ...
- JS动态生成表格后 合并单元格
JS动态生成表格后 合并单元格 最近做项目碰到表格中的单元格合并的问题,需求是这样的,首先发ajax请求 请求回来后的数据 动态生成表格数据,但是生成后如果编号或者(根据其他的内容)有相同时,要合并单 ...
- java使用freemarker模板导出word(带有合并单元格)文档
来自:https://blog.csdn.net/qq_33195578/article/details/73790283 前言:最近要做一个导出word功能,其实网上有很多的例子,但是我需要的是合并 ...
- 【转载】jxl操作excel 字体 背景色 合并单元格 列宽等 .
package com.email.jav; import java.io.File;import java.io.IOException;import java.net.URL; import jx ...
- layui:数据表格如何合并单元格
layui.use('table', function () { var table = layui.table; table.render({ elem: '#applyTab' , url: '$ ...
- Excel表格如何保护单元格不被修改
Excel如何保护单元格不被修改 有时使用Excel时希望保护单元格不被修改,这可以叫做单元格的“写保护”即把光标定位在一个不允许输入数据的区域内时,是无论如何也无法在里面输入数据的.下面咱们就一起 ...
- 填报表导出excel非可写单元格锁定问题
问题描述: 填报表单元格分为可写和不可写两种状态,当填报表在web上展现的时候可写单元格可以进行数据填报和修改,非可写单元格不可操作. 报表导出为excel时,润乾导出excel包默认情况下不对 ...
随机推荐
- zookeeper备忘
ZooInspector https://issues.apache.org/jira/secure/attachment/12436620/ZooInspector.zip 参考:https://b ...
- 使用PYTHON统计项目代码行数
目录 一 使用PYTHON统计项目代码行数 二 应用实例 注:原创不易,转载请务必注明原作者和出处,感谢支持! 一 使用PYTHON统计项目代码行数 遇到一个非常小的需求:统计一个项目里头的各类源代码 ...
- Matlab获取一个文件夹下所有文件名
Matlab获取一个文件夹下所有文件名: fileFolder=fullfile('D:\MATLAB\bin\trc'); dirOutput=dir(fullfile(fileFolder,'*. ...
- Oracle Database的基本概念
一个 Oracle 服务器:是一个关系数据库管理系统(RDBMS),它提供全面的, 近乎完整的信息管理由Oracle 实例和Oracle 数据库组成Oracle 数据库 和 Oracle 实例Orac ...
- document.onselectstart=function(){return false;} 引起的拖动问题
在网页中拖动时,会引起某些文字或一些内容被选中,导致网页中蓝蓝的一片,视觉效果很差,所以我加了个1.document.onselectstart=function(){return false;}或者 ...
- hive基础指令
- 数学建模python matlab 编程(随机游走问题)
1 (1). 随机游走问题.在-10到10的一维线段上,质点以1/5的概率用左运动1单位,以2/5的概率停止不动,以2/5的概率向右运动2单位,且碰到-10时向右运动3单位,碰到10时向左运动4单位. ...
- centos7.5 解决缺少libstdc++.so.6库的原因及解决办法
centos7. 解决缺少libstdc++.so.6库的原因及解决办法 执行node -v报错如下: [root@bogon ~]# node -v node: error : cannot ope ...
- java 增强for循环对于空集和null的判断
List<String> list = null; for (String str : list) {//会报空指针异常 System.out.println(str); } List&l ...
- vue路由传参的几种基本方式
原文地址 this.$router.push跳转 现有如下场景,点击父组件的li元素跳转到子组件中,并携带参数,便于子组件获取数据.父组件中: <li v-for="article i ...