C# NPOI导出datatable----Excel模板画图表

1、创建Excel模板

2、安装NPOI管理包 

3、创建工作簿  (XLSX和XLS步骤一样,以XLS为例)

IWorkbook workbook = null;

 string time = DateTime.Now.ToString("yyyyMMddHHmmss");

string excelTempPath = Application.StartupPath + @"\Excel\分析模板.xls";//分析模板 

string path = Application.StartupPath + @"\Excel\分析文件" + time + ".xls";//保存路径

 //读取Excel模板
using (FileStream fs = new FileStream(excelTempPath, FileMode.Open, FileAccess.Read))
{
   workbook = new HSSFWorkbook(fs);
}

 //获取sheet模板
ISheet  sheet1 = workbook.GetSheetAt(0);
 //将DataSet导出为Excel

4、讲datatable数据写入Excel

                //将DataSet导出为Excel
                int rowCount = dt.Rows.Count;//行数
                int columnCount = dt.Columns.Count;//列数

                //设置列头
                IRow row = sheet1.CreateRow(0);//excel第一行设为列头
                for (int c = 0; c < columnCount; c++)
                {
                    ICell cell = row.CreateCell(c);
                    cell.SetCellValue(dt.Columns[c].ColumnName);
                }
                //设置每行每列的单元格,
                for (int i = 0; i < rowCount; i++)
                {
                    row = sheet1.CreateRow(i + 1);
                    for (int j = 0; j < columnCount; j++)
                    {
                        ICell cell = row.CreateCell(j);//excel第二行开始写入数据
                           if (dt.Rows[i][j].ToString().Length > 0)//判断分数是否为空
                            {//写入数值类型
                                cell.SetCellValue((double)Convert.ToDecimal((dt.Rows[i][j])));
                            }
                            else
                            {//写入文本类型
                                cell.SetCellValue(dt.Rows[i][j].ToString());
                            }
                    }
                }

        workbook.SetSheetName(0, dt.TableName);//修改excel页名为datatable表名

5、向文件输出数据

                 //向outPath输出数据
                using (FileStream fs = File.Open(path, FileMode.Create, FileAccess.Write))
                {
                    workbook.Write(fs);//向打开的这个xls文件中写入数据
                    fs.Close();
                }

  • 21
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C# NPOI 是一个用于处理 Excel 文件的库,它本身并不支持读取图片。如果你想在 Excel 文件中插入图片,可以使用 NPOI 的 `PictureData` 类。以下是一个简单的示例: 1. 首先,确保已经安装了 NPOI 库。你可以通过 NuGet 包管理器来安装。 2. 创建一个新的 C# 项目,并引用 NPOI 和 NPOI.SS.UserModel 命名空间。 3. 使用以下代码将图片插入到 Excel 文件中: ```csharp using System; using System.IO; using NPOI.SS.UserModel; using NPOI.XSSF.UserModel;using NPOI.SS.Util; namespace NPOIExcelImageExample { class Program { static void Main(string[] args) { // 创建一个新的 Excel 工作簿 IWorkbook workbook = new XSSFWorkbook(); // 创建一个新的工作表 ISheet sheet = workbook.CreateSheet("Sheet1"); // 读取图片文件 byte[] imageBytes = File.ReadAllBytes("path/to/your/image.jpg"); // 将图片添加到工作表中 IDrawing drawing = sheet.CreateDrawingPatriarch(); IClientAnchor anchor = drawing.CreateAnchor(0, 0, 0, 0, sheet.LastRowNum - 1, sheet.GetRow(sheet.LastRowNum - 1).LastCellNum - 1, sheet.LastRowNum - 1, sheet.GetRow(sheet.LastRowNum - 1).LastCellNum - 1); IPicture picture = drawing.CreatePicture(anchor, workbook.AddPicture(imageBytes, PictureType.JPEG)); // 保存工作簿到文件 using (FileStream fileStream = new FileStream("output.xlsx", FileMode.Create)) { workbook.Write(fileStream); } Console.WriteLine("图片已成功插入到 Excel 文件中!"); } } } ``` 请将 "path/to/your/image.jpg" 替换为你要插入的图片的实际路径。运行此代码后,将在当前目录下生成一个名为 "output.xlsx" 的 Excel 文件,其中包含插入的图片。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值