社区
.NET技术其他语言
帖子详情
C# 如何自动打印 [.NET技术 C#]
dengkuny
2012-12-22 09:59:02
C# 如何自动打印 [.NET技术 C#]
...全文
125
2
打赏
收藏
C# 如何自动打印 [.NET技术 C#]
C# 如何自动打印 [.NET技术 C#]
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
2 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
cs张
2012-12-23
打赏
举报
回复
楼上的代码强悍~
胡耀文
2012-12-22
打赏
举报
回复
你是指用c#编程?还是问的普通的办公问题?普通办公问题:麻烦你打开“苏州001.doc”,文件->打印->选择好相应城市的打印机->打印编程问题:获取文件名中的城市名你会吧,然后根据城市名得到打印机名(这一步只能你手动设定,比如苏州(城市名)对应打印机名是001,你也可以把对应的打印机名设为城市名 这样就ok了)然后运用打印类: public class RawPrinterHelper { // [Methods] [DllImport("winspool.Drv", CallingConvention = CallingConvention.StdCall, SetLastError = true, ExactSpelling = true)] public static extern bool ClosePrinter(IntPtr hPrinter); [DllImport("winspool.Drv", CallingConvention = CallingConvention.StdCall, SetLastError = true, ExactSpelling = true)] public static extern bool EndDocPrinter(IntPtr hPrinter); [DllImport("winspool.Drv", CallingConvention = CallingConvention.StdCall, SetLastError = true, ExactSpelling = true)] public static extern bool EndPagePrinter(IntPtr hPrinter); [DllImport("winspool.Drv", EntryPoint = "OpenPrinterA", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi, SetLastError = true, ExactSpelling = true)] public static extern bool OpenPrinter([MarshalAs(UnmanagedType.LPStr)] string szPrinter, out IntPtr hPrinter, IntPtr pd); public static bool SendBytesToPrinter(string szPrinterName, IntPtr pBytes, int dwCount) { int dwError = 0; int dwWritten = 0; IntPtr hPrinter = new IntPtr(0); DOCINFOA di = new DOCINFOA(); bool bSuccess = false; di.pDocName = "My C#.NET RAW Document"; di.pDataType = "RAW"; if (OpenPrinter(szPrinterName.Normalize(), out hPrinter, IntPtr.Zero)) { if (StartDocPrinter(hPrinter, 1, di)) { if (StartPagePrinter(hPrinter)) { bSuccess = WritePrinter(hPrinter, pBytes, dwCount, out dwWritten); EndPagePrinter(hPrinter); } EndDocPrinter(hPrinter); } ClosePrinter(hPrinter); } if (!bSuccess) { dwError = Marshal.GetLastWin32Error(); } return bSuccess; } public static bool SendFileToPrinter(string szPrinterName, string szFileName) { FileStream fs = new FileStream(szFileName, FileMode.Open); BinaryReader br = new BinaryReader(fs); byte[] bytes = new byte[fs.Length]; bool bSuccess = false; IntPtr pUnmanagedBytes = new IntPtr(0); int nLength = Convert.ToInt32(fs.Length); bytes = br.ReadBytes(nLength); pUnmanagedBytes = Marshal.AllocCoTaskMem(nLength); Marshal.Copy(bytes, 0, pUnmanagedBytes, nLength); bSuccess = SendBytesToPrinter(szPrinterName, pUnmanagedBytes, nLength); Marshal.FreeCoTaskMem(pUnmanagedBytes); return bSuccess; } public static bool SendStringToPrinter(string szPrinterName, string szString) { int dwCount = szString.Length; IntPtr pBytes = Marshal.StringToCoTaskMemAnsi(szString); SendBytesToPrinter(szPrinterName, pBytes, dwCount); Marshal.FreeCoTaskMem(pBytes); return true; } [DllImport("winspool.Drv", EntryPoint = "StartDocPrinterA", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi, SetLastError = true, ExactSpelling = true)] public static extern bool StartDocPrinter(IntPtr hPrinter, int level, [In, MarshalAs(UnmanagedType.LPStruct)] DOCINFOA di); [DllImport("winspool.Drv", CallingConvention = CallingConvention.StdCall, SetLastError = true, ExactSpelling = true)] public static extern bool StartPagePrinter(IntPtr hPrinter); [DllImport("winspool.Drv", CallingConvention = CallingConvention.StdCall, SetLastError = true, ExactSpelling = true)] public static extern bool WritePrinter(IntPtr hPrinter, IntPtr pBytes, int dwCount, out int dwWritten); //Nested Types [StructLayout(LayoutKind.Sequential)] public class DOCINFOA { [MarshalAs(UnmanagedType.LPStr)] public string pDocName; [MarshalAs(UnmanagedType.LPStr)] public string pOutputFile; [MarshalAs(UnmanagedType.LPStr)] public string pDataType; } }这是网上的一个比较标准的打印类,比较好用,直接copy然后:SendFileToPrinter(打印机名,文件名).
免费DataGridView
打印
及
.NET
轻松
打印
控件5.6版(VB
打印
,
C#
打印
)
本DataGridView
打印
控件和
.NET
打印
控件5.6版(含报表模板设计组件)2014年6月22日修改完成,完全免费,在
.NET
2.0及以上环境下都可以使用(VB
打印
、
C#
打印
都是可以的),有帮助文档与使用实例。 与上一版本的5.5版相比,新控件5.6版的主要更改如下: 1、增加了一个新
打印
组件SimpleReport组件,该组件与DGVPrint组件一样在运行时可进行
打印
参数设置,但比DGVPrint组件功能更强大,可以
自动
管理多个
打印
方案,在
打印
预览时可以自由在各个
打印
方案之间切换;可以在
打印
参数设置窗口中动态定义多表头,还可以像EasyReport组件一样设置和使用参数变量(具体使用效果参见实例程序); 2、解决了EasyReport组件在插入变量参数时,变量参数未排序导致查找不方便的问题; 3、在
打印
预览界面添加了简单的双面
打印
功能。(
打印
预览界面工具栏中的“
打印
\双面
打印
”菜单); 4、其他一些完善,比如DGVPrint组件中设置的行高无效等问题。 本控件特色: 1、强大的DataGridView
打印
功能,不仅可以以多种形式(普通
打印
、分栏
打印
、跨页
打印
、工资条
打印
)
打印
DGV表格,基本上能完全按DGV控件本身设置的格式如字体、字号、背景颜色、前景颜色、单元格对齐方式等
打印
出来,文字图像都可以
打印
,而且是完全根据表格当前的显示顺序进行
打印
的,基本上做到了所见即所得的
打印
。 2、报表设计功能。报表模板设计组件EasyReport与WebEasyReport组件可以设计普通报表、分组报表、套打模板等,分别以DataGridView为数据源。控件的位置以毫米为计量单位,定位准确,很适合套打单据设计。 3、强大的图表
打印
功能。5.2版控件新增了一个Chartlet的组件,使用非常方便,可以生成柱形图、饼图、折线图等多种图形,而且可以设置2D或3D效果,既可以在
打印
控件中
打印
出来,也可以在Graphics对象中显示。 4、分组汇总
打印
DataGridVeiw功能,每组还可以
自动
换新页
打印
,还可以
自动
增加行号。 5、强大的文本
打印
输出功能,控件提供多个文本
打印
重载函数,
打印
文本时,如果需要,控件会
自动
换行和换页
打印
输出。还增加了以指定行间距及字符间距
打印
文本的功能,可以用固定行距,也可以用单倍或多倍行距
打印
文本。 6、强大的绘图功能,基本上
.NET
的GDI+的绘图函数(如直线、矩形、路径、多边形、曲线等)都有,只有个别函数的名称有点区别。 7、支持同一文档多种版面格式
打印
(类似于Word中的节的功能):对同一份文档,不同的页面可以设置不同的格式(纸张大小、纸张方向、页边距),只需要在新增一页时在NewPage方法中指定要使用的页面格式即可,使用非常简单。 8、报表文件保存功能。本控件允许将当前
打印
预览的内容保存为报表文件,以后使用本控件重新打开该报表文件即可重现原来保存报表时的
打印
内容。 9、Excel导出功能,可以将DataGridView和GridView导出为Excel文件,5.2版控件还增加了不依赖Office的导出Excel功能,而且速度非常快,5.4版还增加了合并单元格的导出功能。 10、
打印
DataGridView时的
打印
方案保存与读取功能。可以将当前
打印
参数保存为
打印
方案文件,或者从保存的
打印
方案文件中读取
打印
参数。 11、水印
打印
功能。根据需要,可以在页面中
打印
或不
打印
以半透明空心文字
打印
水印。 12、强大的容器控件
打印
功能(DrawPanel函数)。借助该函数,您只需要在您的容器控件中设计好要
打印
的内容及
打印
内容的相对位置,控件轻松帮你
打印
出来(如果超过一页,控件会
自动
换页续打)。 13、特殊文字效果
打印
功能。控件具有
打印
浮雕文字、阴影文字、空心文字、块文字的功能。 14、页眉页脚中既可
打印
文字,也可
打印
图像,或者即
打印
图像又
打印
输出文字。 15、图像与图标
打印
输出功能。 16、多表头(跨行跨列的复杂表头)
打印
功能,多表头组件支持多表头显示与
打印
、单元格内容的合并显示、
打印
与导出。 17、自定义纸张支持功能。 18、纸张背景图片设置
打印
功能。 19、
.NET
4.0支持功能(是单独的一个文件)。 20、直接
打印
窗口中的TreeView控件功能。 21、
打印
窗口中的ListView功能。 22、RichTextBox控件的RTF文本
打印
功能。 23、斜线表头
打印
功能(5.4版新增)。 24、二维码
打印
功能(5.5版本增加)。 25、5.6版新增的SimpleReport组件允许您在一个方案文件中管理多个
打印
方案,在
打印
预览时能自由在各个
打印
方案之间切换。 我将持续改进该控件,并将不断推出控件的新版本,要查看或下载控件的升级版本,请登陆网站:http://myyouping.download.csdn.n
免费Spire.XLS: 处理Excel文档in
C#
, VB
.NET
Free Spire.XLS for
.NET
是e-iceblue公司开发的一款支持对所有Excel格式类型文件进行操作的
.NET
控件。它适用于任何类型的应用程序比如ASP
.NET
Web应用程序或者Windows桌面应用程序。Spire.XLS for
.NET
允许开发人员创建和管理Excel,而不需要安装Microsoft Excel或者Microsoft Office。相比Microsoft,Spire.XLS for
.NET
对于开发人员来说是一个更好的选择 -
自动
化,安全,稳定,可扩展性延伸,速度快,价格便宜和功能强大。 通过使用Free Spire.XLS for
.NET
,开发人员可以快速方便的查看,生成,读写以及自定义编辑Excel文件。Spire.XLS for
.NET
支持Excel 97-2003, Excel 2007, Excel 2010 and Excel 2013。它还支持
C#
, VB
.NET
, ASP
.NET
和 ASP
.NET
MVC编程语言 作为一款专业,强大,方便易用的控件,Spire.XLS for
.NET
有一下主要功能: 新建Excel文件,编辑已有的Excel文件,多种保存Excel方式,设置Excel文件属性,文件
打印
设置,合并,拆分或者拷贝单元格,支持对Excel文件加锁或者加密保护。 Spire.XLS for
.NET
支持把数据从数据库导出到Excel工作表,或者把数据从Excel数据导入到数据库。 Spire.XLS for
.NET
提供强大的功能为开发者设置单元格格式。这次格式化数字,文字缩进,定位调整,设置单元格边线,单元格填充以及保护等。 开发人员可以轻松的利用Spire.XLS for
.NET
向Excel文件里面写入内容,包括超过530多种的公式,70多种表格,支持插入图片,不同类型的文字,链接,注释甚至VBA等。 Spire.XLS for
.NET
还允许开发人员将Excel文件转换成PDF, HTML, CSV, Text, XML以及图片格式。 注:下载包含有Spire.xls.dll文件以及部分Demo, 你可以调用DLL并参照Demo提供的代码处理Excel文档。
C#
.net
定时器的简单实现
C#
.net
定时器, Timer, 定时任务
C#
二维码生成及批量
打印
C#
二维码生成及批量
打印
C#
二维码生成及批量
打印
C#
二维码生成及批量
打印
C#
二维码生成及批量
打印
C#
二维码生成及批量
打印
C#
二维码生成及批量
打印
C#
实现
打印
PDF文件
C#
多种方法实现
打印
PDF文件,可以指定
打印
机
.NET技术其他语言
1,979
社区成员
12,447
社区内容
发帖
与我相关
我的任务
.NET技术其他语言
.NET技术 其他语言讨论
复制链接
扫一扫
分享
社区描述
.NET技术 其他语言讨论
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章