打印 Excel 模板

大体思路,通过NPOI操作Excel文件,通过Spire将Excel转成图片,将图片传给系统打印。

Spire是收费工具,在微软库中下载Free版本。

#region 打印所用到的函数

private void btnPrint_Click(object sender, EventArgs e)

{

if (!pnlRes.Visible) { MessageBox.Show("请先测量数据!", "提示"); return; }             //未测量无法打印

try

{

Settings.PrintDataRead();

if (File.Exists(Settings.path_printExcel))

{

File.Copy(Settings.path_printExcel, Settings.path_printExcelCopy, true);//三个参数分别是源文件路径,存储路径,若存储路径有相同文件是否替换

}

writeExcel();

prtDoc.PrinterSettings.PrinterName = Settings.PrintData.PrinterName;               //设置打印机名称

System.Drawing.Printing.PaperSize ps = new System.Drawing.Printing.PaperSize();

//ps.RawKind = 150;

ps.Height = Settings.PrintData.PaperSizeHeight - 5;

ps.Width = Settings.PrintData.PaperSizeWidth + 2;

//ps.PaperName = "default";

prtDoc.DefaultPageSettings.PaperSize = ps;

excelToImage(Settings.path_printExcelCopy);

prtDoc.Print();

cleanAll();

File.Delete(Settings.path_printExcelCopy);

}

catch (Exception ex)

{

LogHelper.Error(ex.GetType(), ex);

MessageBox.Show(ex.Message, "错误");

File.Delete(Settings.path_printExcelCopy);

}

}

//写入信息到Excel

private void writeExcel()

{

try

{

string tempPath = Settings.path_printExcelCopy;

//Excel对象

XSSFWorkbook wk = null;

using (FileStream fs = File.Open(tempPath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite))

{

wk = new XSSFWorkbook(fs);

fs.Close();

}

//Excel页面 设置->Sheet1

ISheet sheet = wk.GetSheet("Sheet1");

    /* 写入操作 依据需求自己编写

for (int j = 0; j < chList.Length; ++j)

{

if ((string)chList[j].ckb.Tag != "0")

{

int cell = (j + 1) * 3 - 2;

//写入通道

sheet.GetRow(1).GetCell(cell).SetCellValue("CH" + (j + 1));

//写入OK / NG     Tag 1,OK 2NG

if ((string)chList[j].ckb.Tag == "1")

{

sheet.GetRow(1).GetCell(cell + 1).SetCellValue("OK");

}

else

{

sheet.GetRow(1).GetCell(cell + 1).SetCellValue("NG");

}

//写入机型 时间

sheet.GetRow(2).GetCell(cell).SetCellValue("机型:" + Settings.Model.deviceName);

sheet.GetRow(3).GetCell(cell).SetCellValue(DateTime.Now.ToString("yyyy-MM-dd HH:mm"));

for (int i = 0; i < chList[j].lblList.Length; ++i)

{

switch (i)

{

case 0:

sheet.GetRow(4).GetCell(cell).SetCellValue("流量:" + chList[j].lblList[i].Text);

break;

case 1:

sheet.GetRow(5).GetCell(cell).SetCellValue("出口压力:" + chList[j].lblList[i].Text);

break;

case 2:

sheet.GetRow(6).GetCell(cell).SetCellValue("浓度:" + chList[j].lblList[i].Text);

break;

case 3:

sheet.GetRow(7).GetCell(cell).SetCellValue("雾化压力:" + chList[j].lblList[i].Text);

break;

}

}

}

else

{

}

}

    */

using (var fs = new FileStream(tempPath, FileMode.Create, FileAccess.Write))

{

wk.Write(fs);

}

}

catch (Exception ex)

{

LogHelper.Error(ex.GetType(), ex);

MessageBox.Show(ex.Message, "错误");

}

}

private void excelToImage(string filename)

{

try

{

Workbook workbook = new Workbook();

workbook.LoadFromFile(filename);

Worksheet sheet = workbook.Worksheets[0];

sheet.SaveToImage(Settings.path_printImage); //图片后缀.bmp ,imagepath自己设置

}

catch (Exception ex)

{

LogHelper.Error(ex.GetType(), ex);

MessageBox.Show(ex.Message, "错误");

}

}

private void prtDoc_PrintPage(object sender, System.Drawing.Printing.PrintPageEventArgs e)

{

#region 如果不需要截取图片,可以不用写以下代码

//截取左上角宽度

int rectangleWidth = Settings.PrintData.MarginWidth + 72;

int rectangleHight = Settings.PrintData.MarginHeight + 96;

try

{

GC.Collect();

Graphics g = e.Graphics;

//imagepath是指 excel转成的图片的路径

using (Bitmap bitmap = new Bitmap(Settings.path_printImage))

{

Rectangle newarea = new Rectangle();

newarea.X = rectangleWidth;

newarea.Y = rectangleHight;

newarea.Width = bitmap.Width - rectangleWidth;

newarea.Height = bitmap.Height - rectangleHight;

using (Bitmap newbitmap = bitmap.Clone(newarea, bitmap.PixelFormat))

{

//打印

g.DrawImage(newbitmap, 0, 0, newbitmap.Width, newbitmap.Height);

}

}

}

catch (Exception ex)

{

LogHelper.Error(ex.GetType(), ex);

MessageBox.Show(ex.Message, "错误");

}

#endregion

}

#endregion

C# 调用打印机 打印 Excel的更多相关文章

  1. C# 调用打印机打印文件

    C# 调用打印机打印文件,通常情况下,例如Word.Excel.PDF等可以使用一些对应的组件进行打印,另一个通用的方式是直接启用一个打印的进程进行打印.示例代码如下: using System.Di ...

  2. Java jacob调用打印机打印word文档

    前面说了Java如何生成复杂的Word文档,今年记录下Java如何调用打印机打印word文档. 起初用的是自带的PrintJob,但是系统提供的打印机制并不成熟完整.网上的代码也是千篇一律,在我的打印 ...

  3. aspose调用打印机打印文档

    aspose很不错的插件,功能非常强大,用到了其中的aspose.word. 如何生成word文档,点击. 下面说说如何如何通过打印机打印文档. aspose提供了一个print方法,通过该方法可以直 ...

  4. js调用打印机打印

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. js调用打印机 打印整体或部分

    有时前端的项目中需要添加打印的功能,首先要知道打印分为整体打印和局部打印两种,而局部打印又可细分为局部打印指定的部分,和局部打印指定部分之外的部分.实例比文字看起来更清晰,下面我将用代码来描述 1.整 ...

  6. java生成快递单并调用打印机打印

    生成快递单过程中需要生成条形码,生成条形码可参考:https://www.cnblogs.com/linbky/p/12091248.html 下面这段代码生成的快递单是完全符合京东快递的10 x 1 ...

  7. (转载)js调用打印机 打印整体或部分

    本文转载自:https://www.cnblogs.com/lfhy/p/6802781.html 以下为原文内容: 有时前端的项目中需要添加打印的功能,首先要知道打印分为整体打印和局部打印两种,而局 ...

  8. java 调用打印机 打印服务

    import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;import javax ...

  9. Java调用打印机打印指定路径图片

    依赖 javax.print package com.xgt.util; import org.apache.commons.io.IOUtils; import org.slf4j.Logger; ...

随机推荐

  1. rabbitMQ 的三种Exchange

    rabbitMQ 的Exchange有3种路由方式:  direct.fanout.topic ,以下为详细说明 1.  Direct Exchange 处理路由键.需要将一个队列绑定到交换机上,要求 ...

  2. webview元素定位

    genymotion 模拟器:android  5.0.0 python 2.7 appium 1.4.16.1 1.app原生元素定位(常用) driver.find_element_by_id(“ ...

  3. laravel 资源篇

    转自:https://github.com/qianyugang/learn-laravel # Learn-Laravel — 学习资料和开源项目集 ## Laravel 学习资料 ### 官方网站 ...

  4. 盘符格式转换成NTFS格式

    点击屏幕左下角“开始”,找到运行,在其中输入:cmd,确定,打开“命令提示符”; 在命令提示符下输入: convert X:/FS:NTFS(其中X是你要转换的盘符盘符). 执行后,重新启动电脑 这样 ...

  5. 『TensorFlow』降噪自编码器设计

    背景简介 TensorFlow实现讲解 设计新思路: 1.使用类来记录整个网络: 使用_init_()属性来记录 网络超参数 & 网络框架 & 训练过程 使用一个隐式方法初始化网络参数 ...

  6. js中用户名的正则(字符,数字,下划线,减号)

    <!DOCTYPE html><html><head><meta charset="UTF-8"><title>Inse ...

  7. "她等待刀尖已经太久"--茨维塔耶娃诗抄

      生活   1 你无法夺走我的红晕—— 它强大——如同河水的汛潮! 你是猎人,可我不会上当, 你若追逐,我就会逃跑.   你无法夺走我鲜活的灵魂! 就这样,在急遽的追逐中—— 一匹阿拉伯的骏马, 微 ...

  8. Guava:好用的java类库 学习小记

    基础功能 google guava中定义的String操作 在google guava中为字符串操作提供了很大的便利,有老牌的判断字符串是否为空字符串或者为null,用指定字符填充字符串,以及拆分合并 ...

  9. mac 配置php+php_fpm+nginx

    首先brew安装前面文章上有的 安装nginx  brew install nginx #启动nginx sudo nginx #测试配置是否有语法错误 sudo nginx -t 测试成功 如果不加 ...

  10. 移动web技能总结

    对于作为一名前端开发人员,除了能够编写出满足需求的PC端页面之外,同时也是需要懂得怎么去制作移动web页面,毕竟使用移动设备来操作任何处理称为新时代的趋势,所以学好制作一个移动web时必须滴.于是通过 ...