C#模板打印功能-模板为WPS或Excel
//---WPS-----
using EtApp = ET;
using System.Reflection;
using System.Runtime.InteropServices;
using System.Configuration;
//--Excel--------
using EtAppExcel = Microsoft.Office.Interop.Excel;
namespace LensMaterialPowerCenter.Dorm
{
public
partial class frmDormAllotRoomReportInfo : Office2007Form
{
//--------WPS------
string strProduct = string.Empty;
EtApp.Application objApp = null; //实例WPS Excel类
EtAppExcel.Application objAppExcel = null; //实例Office
Excel类
}
}
//打印两联模板
#region
private void btnTwoPrint_Click(object sender, EventArgs e)
{
try
{
if (dtStaff.Rows.Count == 0)
{
MessageBox.Show("请先选择打印数据记录,请确认!", "提示", MessageBoxButtons.OK,
MessageBoxIcon.Warning);
return;
}
OpenExcelTwoFile();
}
catch { }
}
public void OpenExcelTwoFile()
//打开Excel文件
{
try
{
System.Windows.Forms.OpenFileDialog sfd = new OpenFileDialog();
sfd.DefaultExt = "*.xls";
sfd.Filter = "Any File(*.xls)|*.xls|(*.et)|*.et";
if (sfd.ShowDialog() == DialogResult.OK)
{
//OperateTwo(sfd.FileName);
OperateTwo_Page(sfd.FileName); //---------mark by zl for 测试两联纸
2013-05-20----------
}
}
catch { }
}
private void OperateTwo(string pFileName)
{
try
{
//打开一个WPS Excel应用
objApp = new EtApp.Application();
objApp.DisplayAlerts = false;//DisplayAlerts 属性设置成
False,就不会出现这种警告。
objApp.Visible = false;
if (objApp == null)
{
throw new Exception("打开 WPS Excel应用时发生错误!");
}
EtApp.Workbooks wbs = objApp.Workbooks;
//打开一个现有的工作薄
EtApp._Workbook wb = wbs.Add(pFileName);
EtApp.Sheets shs = wb.Sheets;
//选择第一个Sheet页
EtApp._Worksheet sh = (EtApp._Worksheet)shs.get_Item(1);
string[] str = null;
int page = 0;
if (dtStaff.Rows.Count % 2 == 0)
{
page = dtStaff.Rows.Count / 2;
}
else
{
page = dtStaff.Rows.Count / 2 + 1;
}
for (int i = 0; i < page; i++)
{
sh.Cells[2, 1] = "";
sh.Cells[2, 2] = "";
sh.Cells[2, 3] = "";
//sh.Cells[2, 16] = DateTime.Now.Date;
sh.Cells[2, 4] = "";
sh.Cells[2, 5] = "";
sh.Cells[2, 6] = "";
sh.Cells[6, 1] = "";
sh.Cells[6, 2] = "";
sh.Cells[6, 3] = "";
//sh.Cells[2, 16] = DateTime.Now.Date;
sh.Cells[6, 4] = "";
sh.Cells[6, 5] = "";
sh.Cells[6, 6] = "";
for (int j = i * 2; j < (i * 2) + 2; j++)
{
if (j < dtStaff.Rows.Count)
{
str = new string[6];
str[0] = dtStaff.Rows[j][0].ToString().Trim();
//姓名
str[1] = "'" + dtStaff.Rows[j][1].ToString().Trim(); //身份证号
str[2] = dtStaff.Rows[j][2].ToString().Trim(); //性别
str[3] = dtStaff.Rows[j][3].ToString().Trim();
//宿舍区
str[4] = dtStaff.Rows[j][4].ToString().Trim(); //房号
str[5] = dtStaff.Rows[j][5].ToString().Trim(); //床号
switch ((j + 1) % 2)
{
case 1:
sh.Cells[2, 1] = str[0];
sh.Cells[2, 2] = str[1];
sh.Cells[2, 3] = str[2];
//sh.Cells[2, 16] = DateTime.Now.Date;
sh.Cells[2, 4] = str[3];
sh.Cells[2, 5] = str[4];
sh.Cells[2, 6] = str[5];
sh.Cells[3, 9] =
System.DateTime.Now.Date.ToString("yyyy年MM月dd日");
break;
case 0:
sh.Cells[7, 1] = str[0];
sh.Cells[7, 2] = str[1];
sh.Cells[7, 3] = str[2];
//sh.Cells[2, 16] = DateTime.Now.Date;
sh.Cells[7, 4] = str[3];
sh.Cells[7, 5] = str[4];
sh.Cells[7, 6] = str[5];
sh.Cells[8, 9] =
System.DateTime.Now.Date.ToString("yyyy年MM月dd日");
break;
}
}
}
objApp.Visible = true;
objApp.UserControl = true;
objApp.Visible = true;
objApp.UserControl = true;
///
///打印
///
//wb.PrintPreview(false);
sh.PrintPreview(false);
object oMissing = System.Reflection.Missing.Value;
wb.PrintOut(1, 1, oMissing, oMissing, oMissing, false, false,
oMissing, false, 1, 1, 12124, 12464,
false, ET.ETPaperTray.etPrinterAutomaticSheetFeed, false,
ET.ETPaperOrder.etPrinterOverThenDown);
}
wb.Close(false, null, null); //退出工作薄
objApp.Quit(); //退出wps
System.GC.Collect();
}
catch (Exception theException)
{
String errorMessage;
errorMessage = "Error: ";
errorMessage = String.Concat(errorMessage,
theException.Message);
errorMessage = String.Concat(errorMessage, " Line: ");
errorMessage = String.Concat(errorMessage,
theException.Source);
MessageBox.Show(errorMessage, "Error");
}
}
#region
private void OperateTwo_Page(string pFileName)
{
try
{
//打开一个Office Excel应用
objAppExcel = new EtAppExcel.Application();
objAppExcel.DisplayAlerts = false;//DisplayAlerts 属性设置成
False,就不会出现这种警告。
objAppExcel.Visible = false;
if (objAppExcel == null)
{
throw new Exception("打开 Office Excel应用时发生错误!");
}
EtAppExcel.Workbooks wbs = objAppExcel.Workbooks;
//打开一个现有的工作薄
EtAppExcel._Workbook wb = wbs.Add(pFileName);
EtAppExcel.Sheets shs = wb.Sheets;
//选择第一个Sheet页
EtAppExcel._Worksheet sh =
(EtAppExcel._Worksheet)shs.get_Item(1);
string[] str = null;
int page = 0;
if (dtStaff.Rows.Count % 2 == 0)
{
page = dtStaff.Rows.Count / 2;
}
else
{
page = dtStaff.Rows.Count / 2 + 1;
}
for (int i = 0; i < page; i++)
{
sh.Cells[2, 1] = "";
sh.Cells[2, 2] = "";
sh.Cells[2, 3] = "";
//sh.Cells[2, 16] = DateTime.Now.Date;
sh.Cells[2, 4] = "";
sh.Cells[2, 5] = "";
sh.Cells[2, 6] = "";
sh.Cells[6, 1] = "";
sh.Cells[6, 2] = "";
sh.Cells[6, 3] = "";
//sh.Cells[2, 16] = DateTime.Now.Date;
sh.Cells[6, 4] = "";
sh.Cells[6, 5] = "";
sh.Cells[6, 6] = "";
for (int j = i * 2; j < (i * 2) + 2; j++)
{
if (j < dtStaff.Rows.Count)
{
str = new string[6];
str[0] = dtStaff.Rows[j][0].ToString().Trim();
//姓名
str[1] = "'" + dtStaff.Rows[j][1].ToString().Trim(); //身份证号
str[2] = dtStaff.Rows[j][2].ToString().Trim(); //性别
str[3] = dtStaff.Rows[j][3].ToString().Trim();
//宿舍区
str[4] = dtStaff.Rows[j][4].ToString().Trim(); //房号
str[5] = dtStaff.Rows[j][5].ToString().Trim(); //床号
switch ((j + 1) % 2)
{
case 1:
sh.Cells[2, 1] = str[0];
sh.Cells[2, 2] = str[1];
sh.Cells[2, 3] = str[2];
//sh.Cells[2, 16] = DateTime.Now.Date;
sh.Cells[2, 4] = str[3];
sh.Cells[2, 5] = str[4];
sh.Cells[2, 6] = str[5];
sh.Cells[3, 9] =
System.DateTime.Now.Date.ToString("yyyy年MM月dd日");
break;
case 0:
sh.Cells[7, 1] = str[0];
sh.Cells[7, 2] = str[1];
sh.Cells[7, 3] = str[2];
//sh.Cells[2, 16] = DateTime.Now.Date;
sh.Cells[7, 4] = str[3];
sh.Cells[7, 5] = str[4];
sh.Cells[7, 6] = str[5];
sh.Cells[8, 9] =
System.DateTime.Now.Date.ToString("yyyy年MM月dd日");
break;
}
}
}
objAppExcel.Visible = true;
objAppExcel.UserControl = true;
objAppExcel.Visible = true;
objAppExcel.UserControl = true;
///
///打印
///
//wb.PrintPreview(false);
sh.PrintPreview(false);
object oMissing = System.Reflection.Missing.Value;
//wb.PrintOut(1, 1, oMissing, oMissing, oMissing, false, false,
oMissing, false, 1, 1, 12124, 12464,
// false,
ET.ETPaperTray.etPrinterAutomaticSheetFeed, false,
ET.ETPaperOrder.etPrinterOverThenDown);
wb._PrintOut(1, 1, oMissing, false, oMissing, oMissing,
oMissing);
}
wb.Close(false, null, null); //退出工作薄
objAppExcel.Quit(); //退出wps
System.GC.Collect();
}
catch (Exception theException)
{
String errorMessage;
errorMessage = "Error: ";
errorMessage = String.Concat(errorMessage,
theException.Message);
errorMessage = String.Concat(errorMessage, " Line: ");
errorMessage = String.Concat(errorMessage,
theException.Source);
MessageBox.Show(errorMessage, "Error");
}
}
#endregion
#endregion
C#模板打印功能-模板为WPS或Excel的更多相关文章
- vue-element-admin实现模板打印
一.简介 模板打印也叫”套打“,是业务系统和后台管理系统中的常用功能,B/S系统中实现”套打“比较繁琐,所以很多的B/S系统中的打印功能一直使用的是浏览器打印,很少实现模板打印.本篇将介绍在Vue E ...
- C#用 excel 作为模板打印
//打印操作,套打.打印.预览 enum PrintFlag { /// <summary> /// 套打,只打印没 ...
- 关于opencv模板匹配功能的项目测试记录
模板匹配功能介绍的很好的一篇博客:https://www.cnblogs.com/XJT2018/p/9934139.html 就如上述博客所言:“若原图像中的匹配目标发生旋转或大小变化,该算法无效. ...
- C#微信接口之推送模板消息功能示例
本文实例讲述了C#微信接口之推送模板消息功能.分享给大家供大家参考,具体如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 2 ...
- C++模板常用功能讲解
前言 泛型编程是C++继面向对象编程之后的又一个重点,是为了编写与具体类型无关的代码.而模板是泛型编程的基础.模板简单来理解,可以看作是用宏来实现的,事实上确实有人用宏来实现了模板类似的功能.模板,也 ...
- 按照已有的模板打印小票<二> ——调用windows打印机打印 可设置字体样式
按照已有的模板打印小票<二> ——调用windows打印机打印 可设置字体样式 之前写过一篇文章<按照已有的模板输出一(如发票)>,是关于如何给已有的模板赋值.在项目的实践过程 ...
- Printing tools 自定义模板打印的实现
#ArcGIS for Server 自定义打印两种方法 友好阅读版本: http://gishub.info/2013/09/17/printingtools/ ## 前言使用web打印会遇到中文乱 ...
- ThinkPHP模板包含功能(转载)
对于一些有共同属性的页面(如页脚),可以单独制作成一个模板,再利用 ThinkPHP 提供的模板包含功能包含进来.这样,当要修改这些公共页面时,只需修改对应的模板即可而不必修改每一个页面.模板的包含使 ...
- count_if 功能模板
count_if 功能模板 template <class InputIterator, class UnaryPredicate> typename iterator_traits< ...
随机推荐
- 关于Symfony2+nginx搭建过程总结
关于Symfony2+nginx搭建过程总结 最近在试着用nginx+symfony搭建公司的网站,由于nginx不支持pathinfo模式,所以必须修改nginx(我使用的是nginx1.5.1)的 ...
- Class.forName不能加载abstract原因
今天看到单例模式时,突然想起,单例模式的情况是不让其他类来构造这个类本身,也就是不让new构造器,所以我们一般都会私有化这个构造器.我们知道abstract类是不能实例化的,我想利用abstract这 ...
- Dalvik虚拟机的垃圾收集机制
垃圾收集机制是Java虚拟机共有的特性, 这里介绍Dalvik虚拟机的垃圾收集机制特点. 在android2.3之前,有以下几个特点: 1. 垃圾收集线程在执行的时候,其它线程都停止. 2. 一次 ...
- poj 2485 (kruskal算法)
/*kruskal算法*/ #include <iostream> //#include <fstream> #include <algorithm> using ...
- 工作流--JBPM核心服务及表结构
一. 使用JBPM开发工作流的一般流程 1. jBPM的运行需要数据库的支持,因此系统设计时要选定所用数据库.只要是Hibernate支持的数据库,jBPM就支持.数据库的初始化 ...
- 使用kettle工具将文本文件的内容插入Linux虚拟机下的mysql表中
一. 解压kettle包 1.把包拷到Linux系统下 还有mysql的驱动包 2.解压zip后缀的包 输入命令:unzip /software/pdi-ce-7.0.0.0-25.zip ...
- python-微博模拟登陆
微博的的模拟登陆是比较坑的,看了网上很多大神的帖子,自己又看了微博的登陆时的json数据:1.发现登陆时在输入账号时用chrome可以看到会有一个prelogin之类的网址,网址后面会有大串的随机数. ...
- Spring MVC 返回json数据 报406错误 问题解决方案
将jackson jar包改为jackson-databind-2.5.0.jar jackson-core-2.5.0.jar jackson-annotations-2.5.0.jar(这个版 ...
- find指令参数
1.name ~ 根目录 . 当前和子目录 name之后跟的是文件名 find . -name "[a-z]*[4-9].log" -print 2.perm perm后面跟的是权 ...
- cdh 安装记录
安装文件准备 CDH 下载地址:http://archive.cloudera.com/cdh5/parcels/latest/ 下载操作系统对应的版本: 1.CDH-5.3.0-1.cdh5.3.0 ...