Spire.xls+excel文件实现单据打印

报表和单据打印,通常都是使用fastreport之类的,因为有了现成的xls模板样式,如果转成fastreport那还需要花时间,是用spire.xls这个玩意简单,超好用。

一.引用

using Spire.Xls;

二.基本的操作

// 创建工作簿,读写,保存,保存

private void save_Click(object sender, EventArgs e)

{

Workbook workbook = new Workbook();

workbook.LoadFromFile(Application.StartupPath + "\\sample.xlsx");

// 获取第一个工作表

Worksheet sheet = workbook.Worksheets[0];

// 读取数据

string value1 = sheet.Range["A1"].Value.ToString();

string value2 = sheet.Range["B1"].Value.ToString();

// 写入数据

sheet.Range["A1"].Value = "Hello"; //方式一

sheet.Range[2,2].Value = "World"; //方式二

//保存文件

workbook.SaveToFile("c:\\example.xlsx", ExcelVersion.Version2013);

}
三.打印

使用对话框模式输出,不知道原因是什么,怎么选择打印机都是从默认打印机输出。

myxls.LoadFromFile(Application.StartupPath + "\\sample.xlsx");

sheet = myxls.Worksheets[0];

sheet.PageSetup.PrintArea = "A1:H20";

PrintDialog dialog = new PrintDialog();

dialog.PrinterSettings.PrintRange = System.Drawing.Printing.PrintRange.SomePages;

dialog.PrinterSettings.FromPage = 0;

dialog.AllowPrintToFile = true;

dialog.AllowCurrentPage = true;

dialog.AllowSomePages = true;

myxls.PrintDialog = dialog;

myxls.PrintDocument.PrinterSettings.Copies = 1;

if (dialog.ShowDialog() == DialogResult.OK)

{

myxls.PrintDocument.Print();

}

找不出原因,归结为可能是免费版本限制功能的原因。也不深究,换一个方式,在页面上增加了一个下拉框,窗体加载时将打印机列出来供选择。

using System.Drawing.Printing;

foreach (var item in System.Drawing.Printing.PrinterSettings.InstalledPrinters)

{

this.con_printer.Items.Add(item);

}

this.con_printer.Text= new System.Drawing.Printing.PrintDocument().PrinterSettings.PrinterName;//默认打印机

调用打印的时候,直接指定打印机名称,曲线救国成功。

myxls.PrintDocument.PrintController = new StandardPrintController();

PrinterSettings settings = myxls.PrintDocument.PrinterSettings;

settings.PrinterName = this.con_printer.Text;

settings.Duplex = Duplex.Simplex;

settings.FromPage = 1;

settings.ToPage = 1;

myxls.PrintDocument.Print();

四.插入图片

需要在打印页面插入二维码, 这个先用zxing产生图片,在指定位置插入图片

ExcelPicture mypic = sheet.Pictures.Add(1, 12, Generate3(barcode, 300, 300)); //在第1行12列插入

mypic.Width = 90;

mypic.Height = 90;

mypic.LeftColumnOffset = 75;

mypic.TopRowOffset = 20;

丝滑。

相关推荐
新手unity自用笔记9 小时前
项目-坦克大战学习-子弹的移动与销毁
笔记·学习·c#
qinzechen9 小时前
分享几个做题网站------学习网------工具网;
java·c语言·c++·python·c#
yufei-coder13 小时前
C# Windows 窗体开发基础
vscode·microsoft·c#·visual studio
dangoxiba13 小时前
[Unity Demo]从零开始制作空洞骑士Hollow Knight第十三集:制作小骑士的接触地刺复活机制以及完善地图的可交互对象
游戏·unity·visualstudio·c#·游戏引擎
AitTech13 小时前
深入理解C#中的TimeSpan结构体:创建、访问、计算与格式化
开发语言·数据库·c#
hiyo58517 小时前
C#中虚函数和抽象函数的概念
开发语言·c#
开心工作室_kaic19 小时前
基于微信小程序的校园失物招领系统的设计与实现(论文+源码)_kaic
c语言·javascript·数据库·vue.js·c#·旅游·actionscript
时光追逐者1 天前
WaterCloud:一套基于.NET 8.0 + LayUI的快速开发框架,完全开源免费!
前端·microsoft·开源·c#·.net·layui·.netcore
friklogff1 天前
【C#生态园】打造现代化跨平台应用:深度解析.NET桌面应用工具
开发语言·c#·.net
hiyo5851 天前
C#的面向对象
开发语言·c#